diff --git a/Makefile b/Makefile index 7625f79..d10cde0 100644 --- a/Makefile +++ b/Makefile @@ -35,6 +35,13 @@ CI: black . isort . flake8 . + pytest + +check: + black --check . + isort --check . + flake8 . + pytest pydist: CI make clean diff --git a/comicapi/comicinfoxml.py b/comicapi/comicinfoxml.py index 66a9407..87d75d3 100644 --- a/comicapi/comicinfoxml.py +++ b/comicapi/comicinfoxml.py @@ -18,7 +18,7 @@ import logging import xml.etree.ElementTree as ET from comicapi import utils -from comicapi.genericmetadata import GenericMetadata +from comicapi.genericmetadata import GenericMetadata, PageType from comicapi.issuestring import IssueString logger = logging.getLogger(__name__) @@ -170,6 +170,11 @@ class ComicInfoXml: pages_node = ET.SubElement(root, "Pages") for page_dict in md.pages: + page = page_dict + if "Type" in page: + page["Type"] = page["Type"].value + if "Image" in page: + page["Image"] = str(page["Image"]) page_node = ET.SubElement(pages_node, "Page") page_node.attrib = dict(sorted(page_dict.items())) @@ -251,6 +256,10 @@ class ComicInfoXml: pages_node = root.find("Pages") if pages_node is not None: for page in pages_node: + if "Type" in page.attrib: + page.attrib["Type"] = PageType(page.attrib["Type"]) + if "Image" in page.attrib: + page.attrib["Image"] = int(page.attrib["Image"]) md.pages.append(page.attrib) md.is_empty = False diff --git a/comicapi/genericmetadata.py b/comicapi/genericmetadata.py index db67741..5e0a700 100644 --- a/comicapi/genericmetadata.py +++ b/comicapi/genericmetadata.py @@ -389,36 +389,36 @@ md_test.credits = [ ] md_test.tags = [] md_test.pages = [ - {"Image": "0", "ImageHeight": "1280", "ImageSize": "195977", "ImageWidth": "800", "Type": "FrontCover"}, - {"Image": "1", "ImageHeight": "2039", "ImageSize": "611993", "ImageWidth": "1327"}, - {"Image": "2", "ImageHeight": "2039", "ImageSize": "783726", "ImageWidth": "1327"}, - {"Image": "3", "ImageHeight": "2039", "ImageSize": "679584", "ImageWidth": "1327"}, - {"Image": "4", "ImageHeight": "2039", "ImageSize": "788179", "ImageWidth": "1327"}, - {"Image": "5", "ImageHeight": "2039", "ImageSize": "864433", "ImageWidth": "1327"}, - {"Image": "6", "ImageHeight": "2039", "ImageSize": "765606", "ImageWidth": "1327"}, - {"Image": "7", "ImageHeight": "2039", "ImageSize": "876427", "ImageWidth": "1327"}, - {"Image": "8", "ImageHeight": "2039", "ImageSize": "852622", "ImageWidth": "1327"}, - {"Image": "9", "ImageHeight": "2039", "ImageSize": "800205", "ImageWidth": "1327"}, - {"Image": "10", "ImageHeight": "2039", "ImageSize": "746243", "ImageWidth": "1326"}, - {"Image": "11", "ImageHeight": "2039", "ImageSize": "718062", "ImageWidth": "1327"}, - {"Image": "12", "ImageHeight": "2039", "ImageSize": "532179", "ImageWidth": "1326"}, - {"Image": "13", "ImageHeight": "2039", "ImageSize": "686708", "ImageWidth": "1327"}, - {"Image": "14", "ImageHeight": "2039", "ImageSize": "641907", "ImageWidth": "1327"}, - {"Image": "15", "ImageHeight": "2039", "ImageSize": "805388", "ImageWidth": "1327"}, - {"Image": "16", "ImageHeight": "2039", "ImageSize": "668927", "ImageWidth": "1326"}, - {"Image": "17", "ImageHeight": "2039", "ImageSize": "710605", "ImageWidth": "1327"}, - {"Image": "18", "ImageHeight": "2039", "ImageSize": "761398", "ImageWidth": "1326"}, - {"Image": "19", "ImageHeight": "2039", "ImageSize": "743807", "ImageWidth": "1327"}, - {"Image": "20", "ImageHeight": "2039", "ImageSize": "552911", "ImageWidth": "1326"}, - {"Image": "21", "ImageHeight": "2039", "ImageSize": "556827", "ImageWidth": "1327"}, - {"Image": "22", "ImageHeight": "2039", "ImageSize": "675078", "ImageWidth": "1326"}, + {"Image": 0, "ImageHeight": "1280", "ImageSize": "195977", "ImageWidth": "800", "Type": PageType.FrontCover}, + {"Image": 1, "ImageHeight": "2039", "ImageSize": "611993", "ImageWidth": "1327"}, + {"Image": 2, "ImageHeight": "2039", "ImageSize": "783726", "ImageWidth": "1327"}, + {"Image": 3, "ImageHeight": "2039", "ImageSize": "679584", "ImageWidth": "1327"}, + {"Image": 4, "ImageHeight": "2039", "ImageSize": "788179", "ImageWidth": "1327"}, + {"Image": 5, "ImageHeight": "2039", "ImageSize": "864433", "ImageWidth": "1327"}, + {"Image": 6, "ImageHeight": "2039", "ImageSize": "765606", "ImageWidth": "1327"}, + {"Image": 7, "ImageHeight": "2039", "ImageSize": "876427", "ImageWidth": "1327"}, + {"Image": 8, "ImageHeight": "2039", "ImageSize": "852622", "ImageWidth": "1327"}, + {"Image": 9, "ImageHeight": "2039", "ImageSize": "800205", "ImageWidth": "1327"}, + {"Image": 10, "ImageHeight": "2039", "ImageSize": "746243", "ImageWidth": "1326"}, + {"Image": 11, "ImageHeight": "2039", "ImageSize": "718062", "ImageWidth": "1327"}, + {"Image": 12, "ImageHeight": "2039", "ImageSize": "532179", "ImageWidth": "1326"}, + {"Image": 13, "ImageHeight": "2039", "ImageSize": "686708", "ImageWidth": "1327"}, + {"Image": 14, "ImageHeight": "2039", "ImageSize": "641907", "ImageWidth": "1327"}, + {"Image": 15, "ImageHeight": "2039", "ImageSize": "805388", "ImageWidth": "1327"}, + {"Image": 16, "ImageHeight": "2039", "ImageSize": "668927", "ImageWidth": "1326"}, + {"Image": 17, "ImageHeight": "2039", "ImageSize": "710605", "ImageWidth": "1327"}, + {"Image": 18, "ImageHeight": "2039", "ImageSize": "761398", "ImageWidth": "1326"}, + {"Image": 19, "ImageHeight": "2039", "ImageSize": "743807", "ImageWidth": "1327"}, + {"Image": 20, "ImageHeight": "2039", "ImageSize": "552911", "ImageWidth": "1326"}, + {"Image": 21, "ImageHeight": "2039", "ImageSize": "556827", "ImageWidth": "1327"}, + {"Image": 22, "ImageHeight": "2039", "ImageSize": "675078", "ImageWidth": "1326"}, { "Bookmark": "Interview", "Image": "23", "ImageHeight": "2032", "ImageSize": "800965", "ImageWidth": "1338", - "Type": "Letters", + "Type": PageType.Letters, }, ] md_test.price = None diff --git a/comictaggerlib/pagelisteditor.py b/comictaggerlib/pagelisteditor.py index b463e5a..100e315 100644 --- a/comictaggerlib/pagelisteditor.py +++ b/comictaggerlib/pagelisteditor.py @@ -263,7 +263,7 @@ class PageListEditor(QtWidgets.QWidget): if "Type" in page_dict: del page_dict["Type"] else: - page_dict["Type"] = str(t) + page_dict["Type"] = t item = self.listWidget.item(row) # wrap the dict in a tuple to keep from being converted to QtWidgets.QStrings diff --git a/tests/data/Cory Doctorow's Futuristic Tales of the Here and Now #001 - Anda's Game (2007).cbz b/tests/data/Cory Doctorow's Futuristic Tales of the Here and Now #001 - Anda's Game (2007).cbz new file mode 100644 index 0000000..035a7ec Binary files /dev/null and b/tests/data/Cory Doctorow's Futuristic Tales of the Here and Now #001 - Anda's Game (2007).cbz differ diff --git a/tests/test_comicarchive.py b/tests/test_comicarchive.py index 32008a6..5cd8644 100644 --- a/tests/test_comicarchive.py +++ b/tests/test_comicarchive.py @@ -1,8 +1,10 @@ +import shutil from os.path import abspath, dirname, join import pytest from comicapi.comicarchive import ComicArchive, rar_support +from comicapi.genericmetadata import GenericMetadata, PageType, md_test thisdir = dirname(abspath(__file__)) @@ -21,3 +23,37 @@ def test_getPageNameList(): "page4.webp", "page10.jpg", ] + + +def test_set_default_page_list(tmpdir): + md = GenericMetadata() + md.overlay(md_test) + md.pages = [] + print(md_test.pages, md.pages) + md.set_default_page_list(len(md_test.pages)) + + assert isinstance(md.pages[0]["Image"], int) + + +def test_page_type(): + c_path = join(thisdir, "data", "Cory Doctorow's Futuristic Tales of the Here and Now #001 - Anda's Game (2007).cbz") + c = ComicArchive(str(c_path)) + md = c.read_cix() + + assert isinstance(md.pages[0]["Type"], PageType) + + +def test_save_cix(tmpdir): + comic_path = tmpdir.mkdir("cbz").join( + "Cory Doctorow's Futuristic Tales of the Here and Now #001 - Anda's Game (2007).cbz" + ) + c_path = join(thisdir, "data", "Cory Doctorow's Futuristic Tales of the Here and Now #001 - Anda's Game (2007).cbz") + shutil.copy(c_path, comic_path) + + c = ComicArchive(str(comic_path)) + md = c.read_cix() + md.set_default_page_list(c.get_number_of_pages()) + + assert c.write_cix(md) + + md = c.read_cix()