Start Time: 2024-01-15 19:07:05
Stop Time: 2024-01-16 00:20:43
Duration: 4h 41 min
| Test Group/Test case | Count | Pass | Fail | Error | Skip | View | 
| TestAnonymous | 13 | 13 | 0 | 0 | 0 | Detail | 
| TestAnonymous - test_check_locale_guest | PASS | |||||
| TestAnonymous - test_guest_about | PASS | |||||
| TestAnonymous - test_guest_change_visibility_category | PASS | |||||
| TestAnonymous - test_guest_change_visibility_format | PASS | |||||
| TestAnonymous - test_guest_change_visibility_hot | PASS | |||||
| TestAnonymous - test_guest_change_visibility_language | PASS | |||||
| TestAnonymous - test_guest_change_visibility_publisher | PASS | |||||
| TestAnonymous - test_guest_change_visibility_rated | PASS | |||||
| TestAnonymous - test_guest_change_visibility_rating | PASS | |||||
| TestAnonymous - test_guest_change_visibility_series | PASS | |||||
| TestAnonymous - test_guest_random_books_available | PASS | |||||
| TestAnonymous - test_guest_restricted_settings_visibility | PASS | |||||
| TestAnonymous - test_guest_visibility_sidebar | PASS | |||||
| TestBackupMetadata | 21 | 20 | 1 | 0 | 0 | Detail | 
| TestBackupMetadata - test_backup_all | PASS | |||||
| TestBackupMetadata - test_backup_change_book_author | PASS | |||||
| TestBackupMetadata - test_backup_change_book_description | PASS | |||||
| TestBackupMetadata - test_backup_change_book_identifier | PASS | |||||
| TestBackupMetadata - test_backup_change_book_language | PASS | |||||
| TestBackupMetadata - test_backup_change_book_publisher | PASS | |||||
| TestBackupMetadata - test_backup_change_book_publishing_date | PASS | |||||
| TestBackupMetadata - test_backup_change_book_rating | PASS | |||||
| TestBackupMetadata - test_backup_change_book_series_index | Traceback (most recent call last):
  File "/home/ozzie/Development/calibre-web-test/test/test_backup_metadata.py", line 139, in test_backup_change_book_series_index
    self.assertEqual(metadata['series']['content'], "t,st")
AssertionError: 'tEst' != 't,st'
- tEst
?  ^
+ t,st
?  ^ | |||||
| TestBackupMetadata - test_backup_change_book_tags | PASS | |||||
| TestBackupMetadata - test_backup_change_book_title | PASS | |||||
| TestBackupMetadata - test_backup_change_custom_Comment | PASS | |||||
| TestBackupMetadata - test_backup_change_custom_Enum | PASS | |||||
| TestBackupMetadata - test_backup_change_custom_bool | PASS | |||||
| TestBackupMetadata - test_backup_change_custom_categories | PASS | |||||
| TestBackupMetadata - test_backup_change_custom_date | PASS | |||||
| TestBackupMetadata - test_backup_change_custom_float | PASS | |||||
| TestBackupMetadata - test_backup_change_custom_int | PASS | |||||
| TestBackupMetadata - test_backup_change_custom_rating | PASS | |||||
| TestBackupMetadata - test_backup_change_custom_text | PASS | |||||
| TestBackupMetadata - test_upload_book | PASS | |||||
| _ErrorHolder | 7 | 0 | 0 | 7 | 0 | Detail | 
| setUpClass (test_backup_metadata_gdrive) | Traceback (most recent call last):
  File "/home/ozzie/Development/calibre-web-test/test/test_backup_metadata_gdrive.py", line 37, in setUpClass
    prepare_gdrive()
  File "/home/ozzie/Development/calibre-web-test/test/helper_gdrive.py", line 31, in prepare_gdrive
    fs.removetree('test')
  File "/home/ozzie/Development/calibre-web-test/venv/lib/python3.10/site-packages/fs/base.py", line 1320, in removetree
    self.remove(_path)
  File "/home/ozzie/Development/calibre-web-test/venv/lib/python3.10/site-packages/fs/googledrivefs/googledrivefs.py", line 470, in remove
    metadata = self._itemFromPath(path)
  File "/home/ozzie/Development/calibre-web-test/venv/lib/python3.10/site-packages/fs/googledrivefs/googledrivefs.py", line 262, in _itemFromPath
    pathIdMap = self._itemsFromPath(path)
  File "/home/ozzie/Development/calibre-web-test/venv/lib/python3.10/site-packages/fs/googledrivefs/googledrivefs.py", line 252, in _itemsFromPath
    metadata = self._childByName(parentId, childName)
  File "/home/ozzie/Development/calibre-web-test/venv/lib/python3.10/site-packages/fs/googledrivefs/googledrivefs.py", line 225, in _childByName
    raise RuntimeError(f'Folder with id {parentId} has more than 1 child with name {childName}')
RuntimeError: Folder with id 1hm1as7vS6yPzUFGWzFAMYQ-SqvhWJ_Df has more than 1 child with name cover.jpg | |||||
| setUpClass (test_cli_gdrive) | Traceback (most recent call last):
  File "/home/ozzie/Development/calibre-web-test/test/test_cli_gdrive.py", line 36, in setUpClass
    prepare_gdrive()
  File "/home/ozzie/Development/calibre-web-test/test/helper_gdrive.py", line 31, in prepare_gdrive
    fs.removetree('test')
  File "/home/ozzie/Development/calibre-web-test/venv/lib/python3.10/site-packages/fs/base.py", line 1320, in removetree
    self.remove(_path)
  File "/home/ozzie/Development/calibre-web-test/venv/lib/python3.10/site-packages/fs/googledrivefs/googledrivefs.py", line 470, in remove
    metadata = self._itemFromPath(path)
  File "/home/ozzie/Development/calibre-web-test/venv/lib/python3.10/site-packages/fs/googledrivefs/googledrivefs.py", line 262, in _itemFromPath
    pathIdMap = self._itemsFromPath(path)
  File "/home/ozzie/Development/calibre-web-test/venv/lib/python3.10/site-packages/fs/googledrivefs/googledrivefs.py", line 252, in _itemsFromPath
    metadata = self._childByName(parentId, childName)
  File "/home/ozzie/Development/calibre-web-test/venv/lib/python3.10/site-packages/fs/googledrivefs/googledrivefs.py", line 225, in _childByName
    raise RuntimeError(f'Folder with id {parentId} has more than 1 child with name {childName}')
RuntimeError: Folder with id 1hm1as7vS6yPzUFGWzFAMYQ-SqvhWJ_Df has more than 1 child with name cover.jpg | |||||
| setUpClass (test_ebook_convert_gdrive) | Traceback (most recent call last):
  File "/home/ozzie/Development/calibre-web-test/test/test_ebook_convert_gdrive.py", line 45, in setUpClass
    prepare_gdrive()
  File "/home/ozzie/Development/calibre-web-test/test/helper_gdrive.py", line 31, in prepare_gdrive
    fs.removetree('test')
  File "/home/ozzie/Development/calibre-web-test/venv/lib/python3.10/site-packages/fs/base.py", line 1320, in removetree
    self.remove(_path)
  File "/home/ozzie/Development/calibre-web-test/venv/lib/python3.10/site-packages/fs/googledrivefs/googledrivefs.py", line 470, in remove
    metadata = self._itemFromPath(path)
  File "/home/ozzie/Development/calibre-web-test/venv/lib/python3.10/site-packages/fs/googledrivefs/googledrivefs.py", line 262, in _itemFromPath
    pathIdMap = self._itemsFromPath(path)
  File "/home/ozzie/Development/calibre-web-test/venv/lib/python3.10/site-packages/fs/googledrivefs/googledrivefs.py", line 252, in _itemsFromPath
    metadata = self._childByName(parentId, childName)
  File "/home/ozzie/Development/calibre-web-test/venv/lib/python3.10/site-packages/fs/googledrivefs/googledrivefs.py", line 225, in _childByName
    raise RuntimeError(f'Folder with id {parentId} has more than 1 child with name {childName}')
RuntimeError: Folder with id 1hm1as7vS6yPzUFGWzFAMYQ-SqvhWJ_Df has more than 1 child with name cover.jpg | |||||
| setUpClass (test_ebook_convert_kepubify_gdrive) | Traceback (most recent call last):
  File "/home/ozzie/Development/calibre-web-test/test/test_ebook_convert_kepubify_gdrive.py", line 38, in setUpClass
    prepare_gdrive()
  File "/home/ozzie/Development/calibre-web-test/test/helper_gdrive.py", line 31, in prepare_gdrive
    fs.removetree('test')
  File "/home/ozzie/Development/calibre-web-test/venv/lib/python3.10/site-packages/fs/base.py", line 1320, in removetree
    self.remove(_path)
  File "/home/ozzie/Development/calibre-web-test/venv/lib/python3.10/site-packages/fs/googledrivefs/googledrivefs.py", line 470, in remove
    metadata = self._itemFromPath(path)
  File "/home/ozzie/Development/calibre-web-test/venv/lib/python3.10/site-packages/fs/googledrivefs/googledrivefs.py", line 262, in _itemFromPath
    pathIdMap = self._itemsFromPath(path)
  File "/home/ozzie/Development/calibre-web-test/venv/lib/python3.10/site-packages/fs/googledrivefs/googledrivefs.py", line 252, in _itemsFromPath
    metadata = self._childByName(parentId, childName)
  File "/home/ozzie/Development/calibre-web-test/venv/lib/python3.10/site-packages/fs/googledrivefs/googledrivefs.py", line 225, in _childByName
    raise RuntimeError(f'Folder with id {parentId} has more than 1 child with name {childName}')
RuntimeError: Folder with id 1hm1as7vS6yPzUFGWzFAMYQ-SqvhWJ_Df has more than 1 child with name cover.jpg | |||||
| setUpClass (test_edit_books_author_gdrive) | Traceback (most recent call last):
  File "/home/ozzie/Development/calibre-web-test/test/test_edit_books_author_gdrive.py", line 38, in setUpClass
    prepare_gdrive()
  File "/home/ozzie/Development/calibre-web-test/test/helper_gdrive.py", line 31, in prepare_gdrive
    fs.removetree('test')
  File "/home/ozzie/Development/calibre-web-test/venv/lib/python3.10/site-packages/fs/base.py", line 1320, in removetree
    self.remove(_path)
  File "/home/ozzie/Development/calibre-web-test/venv/lib/python3.10/site-packages/fs/googledrivefs/googledrivefs.py", line 470, in remove
    metadata = self._itemFromPath(path)
  File "/home/ozzie/Development/calibre-web-test/venv/lib/python3.10/site-packages/fs/googledrivefs/googledrivefs.py", line 262, in _itemFromPath
    pathIdMap = self._itemsFromPath(path)
  File "/home/ozzie/Development/calibre-web-test/venv/lib/python3.10/site-packages/fs/googledrivefs/googledrivefs.py", line 252, in _itemsFromPath
    metadata = self._childByName(parentId, childName)
  File "/home/ozzie/Development/calibre-web-test/venv/lib/python3.10/site-packages/fs/googledrivefs/googledrivefs.py", line 225, in _childByName
    raise RuntimeError(f'Folder with id {parentId} has more than 1 child with name {childName}')
RuntimeError: Folder with id 1hm1as7vS6yPzUFGWzFAMYQ-SqvhWJ_Df has more than 1 child with name cover.jpg | |||||
| setUpClass (test_edit_ebooks_gdrive) | Traceback (most recent call last):
  File "/home/ozzie/Development/calibre-web-test/test/test_edit_ebooks_gdrive.py", line 41, in setUpClass
    prepare_gdrive()
  File "/home/ozzie/Development/calibre-web-test/test/helper_gdrive.py", line 31, in prepare_gdrive
    fs.removetree('test')
  File "/home/ozzie/Development/calibre-web-test/venv/lib/python3.10/site-packages/fs/base.py", line 1320, in removetree
    self.remove(_path)
  File "/home/ozzie/Development/calibre-web-test/venv/lib/python3.10/site-packages/fs/googledrivefs/googledrivefs.py", line 470, in remove
    metadata = self._itemFromPath(path)
  File "/home/ozzie/Development/calibre-web-test/venv/lib/python3.10/site-packages/fs/googledrivefs/googledrivefs.py", line 262, in _itemFromPath
    pathIdMap = self._itemsFromPath(path)
  File "/home/ozzie/Development/calibre-web-test/venv/lib/python3.10/site-packages/fs/googledrivefs/googledrivefs.py", line 252, in _itemsFromPath
    metadata = self._childByName(parentId, childName)
  File "/home/ozzie/Development/calibre-web-test/venv/lib/python3.10/site-packages/fs/googledrivefs/googledrivefs.py", line 225, in _childByName
    raise RuntimeError(f'Folder with id {parentId} has more than 1 child with name {childName}')
RuntimeError: Folder with id 1hm1as7vS6yPzUFGWzFAMYQ-SqvhWJ_Df has more than 1 child with name cover.jpg | |||||
| setUpClass (test_embed_metadata_gdrive) | Traceback (most recent call last):
  File "/home/ozzie/Development/calibre-web-test/test/test_embed_metadata_gdrive.py", line 34, in setUpClass
    prepare_gdrive()
  File "/home/ozzie/Development/calibre-web-test/test/helper_gdrive.py", line 31, in prepare_gdrive
    fs.removetree('test')
  File "/home/ozzie/Development/calibre-web-test/venv/lib/python3.10/site-packages/fs/base.py", line 1320, in removetree
    self.remove(_path)
  File "/home/ozzie/Development/calibre-web-test/venv/lib/python3.10/site-packages/fs/googledrivefs/googledrivefs.py", line 470, in remove
    metadata = self._itemFromPath(path)
  File "/home/ozzie/Development/calibre-web-test/venv/lib/python3.10/site-packages/fs/googledrivefs/googledrivefs.py", line 262, in _itemFromPath
    pathIdMap = self._itemsFromPath(path)
  File "/home/ozzie/Development/calibre-web-test/venv/lib/python3.10/site-packages/fs/googledrivefs/googledrivefs.py", line 252, in _itemsFromPath
    metadata = self._childByName(parentId, childName)
  File "/home/ozzie/Development/calibre-web-test/venv/lib/python3.10/site-packages/fs/googledrivefs/googledrivefs.py", line 225, in _childByName
    raise RuntimeError(f'Folder with id {parentId} has more than 1 child with name {childName}')
RuntimeError: Folder with id 1hm1as7vS6yPzUFGWzFAMYQ-SqvhWJ_Df has more than 1 child with name cover.jpg | |||||
| TestCli | 13 | 12 | 1 | 0 | 0 | Detail | 
| TestCli - test_already_started | PASS | |||||
| TestCli - test_bind_to_single_interface | PASS | |||||
| TestCli - test_change_password | PASS | |||||
| TestCli - test_cli_SSL_files | PASS | |||||
| TestCli - test_cli_different_folder | PASS | |||||
| TestCli - test_cli_different_settings_database | PASS | |||||
| TestCli - test_dryrun_update | PASS | |||||
| TestCli - test_enable_reconnect | PASS | |||||
| TestCli - test_environ_port_setting | PASS | |||||
| TestCli - test_logfile | Traceback (most recent call last):
  File "/home/ozzie/Development/calibre-web-test/test/test_cli.py", line 642, in test_logfile
    self.assertTrue("Starting Calibre Web..." in lines, lines)
AssertionError: False is not true : [2024-01-15 19:40:42,385]  WARN {cps.config_sql:395} invalidating configuration
[2024-01-15 19:40:42,406]  INFO {cps:168} *** "google-api-python-client" version does not meet the requirements. Should: <2.108.0, Found: 2.113.0, please consider installing required version ***
[2024-01-15 19:40:42,406]  INFO {cps:168} *** "greenlet" version does not meet the requirements. Should: <2.1.0, Found: 3.0.3, please consider installing required version ***
[2024-01-15 19:40:42,406]  INFO {cps:168} *** "PyDrive2" version does not meet the requirements. Should: <1.18.0, Found: 1.19.0, please consider installing required version ***
[2024-01-15 19:40:42,406]  INFO {cps:168} *** "google-api-python-client" version does not meet the requirements. Should: <2.108.0, Found: 2.113.0, please consider installing required version *** | |||||
| TestCli - test_no_database | PASS | |||||
| TestCli - test_settingsdb_not_writeable | PASS | |||||
| TestCli - test_writeonly_static_files | PASS | |||||
| _FailedTest | 2 | 0 | 0 | 2 | 0 | Detail | 
| _FailedTest - test_cover_edit_books | ImportError: Failed to import test module: test_cover_edit_books
Traceback (most recent call last):
  File "/usr/lib/python3.10/unittest/loader.py", line 436, in _find_test_path
    module = self._get_module_from_name(name)
  File "/usr/lib/python3.10/unittest/loader.py", line 377, in _get_module_from_name
    __import__(name)
  File "/home/ozzie/Development/calibre-web-test/test/test_cover_edit_books.py", line 14, in <module>
    from helper_proxy import Proxy, val
  File "/home/ozzie/Development/calibre-web-test/test/helper_proxy.py", line 1, in <module>
    from mitmproxy import proxy, options
  File "/home/ozzie/Development/calibre-web-test/venv/lib/python3.10/site-packages/mitmproxy/proxy/__init__.py", line 1, in <module>
    from .config import ProxyConfig
  File "/home/ozzie/Development/calibre-web-test/venv/lib/python3.10/site-packages/mitmproxy/proxy/config.py", line 9, in <module>
    from mitmproxy import options as moptions
  File "/home/ozzie/Development/calibre-web-test/venv/lib/python3.10/site-packages/mitmproxy/options.py", line 4, in <module>
    from mitmproxy.net import tls
  File "/home/ozzie/Development/calibre-web-test/venv/lib/python3.10/site-packages/mitmproxy/net/tls.py", line 43, in <module>
    "SSLv2": (SSL.SSLv2_METHOD, BASIC_OPTIONS),
AttributeError: module 'OpenSSL.SSL' has no attribute 'SSLv2_METHOD' | |||||
| _FailedTest - test_updater | ImportError: Failed to import test module: test_updater
Traceback (most recent call last):
  File "/usr/lib/python3.10/unittest/loader.py", line 436, in _find_test_path
    module = self._get_module_from_name(name)
  File "/usr/lib/python3.10/unittest/loader.py", line 377, in _get_module_from_name
    __import__(name)
  File "/home/ozzie/Development/calibre-web-test/test/test_updater.py", line 13, in <module>
    from helper_proxy import Proxy, val
  File "/home/ozzie/Development/calibre-web-test/test/helper_proxy.py", line 1, in <module>
    from mitmproxy import proxy, options
  File "/home/ozzie/Development/calibre-web-test/venv/lib/python3.10/site-packages/mitmproxy/proxy/__init__.py", line 1, in <module>
    from .config import ProxyConfig
  File "/home/ozzie/Development/calibre-web-test/venv/lib/python3.10/site-packages/mitmproxy/proxy/config.py", line 9, in <module>
    from mitmproxy import options as moptions
  File "/home/ozzie/Development/calibre-web-test/venv/lib/python3.10/site-packages/mitmproxy/options.py", line 4, in <module>
    from mitmproxy.net import tls
  File "/home/ozzie/Development/calibre-web-test/venv/lib/python3.10/site-packages/mitmproxy/net/tls.py", line 43, in <module>
    "SSLv2": (SSL.SSLv2_METHOD, BASIC_OPTIONS),
AttributeError: module 'OpenSSL.SSL' has no attribute 'SSLv2_METHOD' | |||||
| TestDeleteDatabase | 1 | 1 | 0 | 0 | 0 | Detail | 
| TestDeleteDatabase - test_delete_books_in_database | PASS | |||||
| TestEbookConvertCalibre | 15 | 15 | 0 | 0 | 0 | Detail | 
| TestEbookConvertCalibre - test_calibre_log | PASS | |||||
| TestEbookConvertCalibre - test_convert_deactivate | PASS | |||||
| TestEbookConvertCalibre - test_convert_email | PASS | |||||
| TestEbookConvertCalibre - test_convert_failed_and_email | PASS | |||||
| TestEbookConvertCalibre - test_convert_only | PASS | |||||
| TestEbookConvertCalibre - test_convert_options | PASS | |||||
| TestEbookConvertCalibre - test_convert_parameter | PASS | |||||
| TestEbookConvertCalibre - test_convert_wrong_excecutable | PASS | |||||
| TestEbookConvertCalibre - test_convert_xss | PASS | |||||
| TestEbookConvertCalibre - test_email_failed | PASS | |||||
| TestEbookConvertCalibre - test_email_only | PASS | |||||
| TestEbookConvertCalibre - test_kindle_send_not_configured | PASS | |||||
| TestEbookConvertCalibre - test_ssl_smtp_setup_error | PASS | |||||
| TestEbookConvertCalibre - test_starttls_smtp_setup_error | PASS | |||||
| TestEbookConvertCalibre - test_user_convert_xss | PASS | |||||
| TestEbookConvertKepubify | 3 | 3 | 0 | 0 | 0 | Detail | 
| TestEbookConvertKepubify - test_convert_deactivate | PASS | |||||
| TestEbookConvertKepubify - test_convert_only | PASS | |||||
| TestEbookConvertKepubify - test_convert_wrong_excecutable | PASS | |||||
| TestEditAdditionalBooks | 20 | 18 | 0 | 0 | 2 | Detail | 
| TestEditAdditionalBooks - test_cbz_comicinfo | PASS | |||||
| TestEditAdditionalBooks - test_change_upload_formats | PASS | |||||
| TestEditAdditionalBooks - test_delete_book | PASS | |||||
| TestEditAdditionalBooks - test_delete_role | PASS | |||||
| TestEditAdditionalBooks - test_details_popup | PASS | |||||
| TestEditAdditionalBooks - test_edit_book_identifier | PASS | |||||
| TestEditAdditionalBooks - test_edit_book_identifier_capital | PASS | |||||
| TestEditAdditionalBooks - test_edit_book_identifier_standard | PASS | |||||
| TestEditAdditionalBooks - test_edit_special_book_identifier | PASS | |||||
| TestEditAdditionalBooks - test_title_sort | PASS | |||||
| TestEditAdditionalBooks - test_upload_cbz_coverformats | PASS | |||||
| TestEditAdditionalBooks - test_upload_edit_role | PASS | |||||
| TestEditAdditionalBooks - test_upload_metadata_cb7 | PASS | |||||
| TestEditAdditionalBooks - test_upload_metadata_cbr | PASS | |||||
| TestEditAdditionalBooks - test_upload_metadata_cbt | PASS | |||||
| TestEditAdditionalBooks - test_writeonly_calibre_database | ||||||
| TestEditAdditionalBooks - test_writeonly_path | PASS | |||||
| TestEditAdditionalBooks - test_xss_author_edit | SKIP | |||||
| TestEditAdditionalBooks - test_xss_comment_edit | PASS | |||||
| TestEditAdditionalBooks - test_xss_custom_comment_edit | PASS | |||||
| TestEditBooks | 38 | 36 | 0 | 0 | 2 | Detail | 
| TestEditBooks - test_download_book | PASS | |||||
| TestEditBooks - test_edit_author | PASS | |||||
| TestEditBooks - test_edit_category | PASS | |||||
| TestEditBooks - test_edit_comments | PASS | |||||
| TestEditBooks - test_edit_custom_bool | PASS | |||||
| TestEditBooks - test_edit_custom_categories | PASS | |||||
| TestEditBooks - test_edit_custom_comment | PASS | |||||
| TestEditBooks - test_edit_custom_date | PASS | |||||
| TestEditBooks - test_edit_custom_float | PASS | |||||
| TestEditBooks - test_edit_custom_int | PASS | |||||
| TestEditBooks - test_edit_custom_rating | PASS | |||||
| TestEditBooks - test_edit_custom_single_select | PASS | |||||
| TestEditBooks - test_edit_custom_text | PASS | |||||
| TestEditBooks - test_edit_language | PASS | |||||
| TestEditBooks - test_edit_publisher | PASS | |||||
| TestEditBooks - test_edit_publishing_date | PASS | |||||
| TestEditBooks - test_edit_rating | PASS | |||||
| TestEditBooks - test_edit_series | PASS | |||||
| TestEditBooks - test_edit_title | PASS | |||||
| TestEditBooks - test_rename_upper_lowercase | ||||||
| TestEditBooks - test_rename_uppercase_lowercase | ||||||
| TestEditBooks - test_typeahead_author | PASS | |||||
| TestEditBooks - test_typeahead_functions | PASS | |||||
| TestEditBooks - test_typeahead_language | PASS | |||||
| TestEditBooks - test_typeahead_publisher | PASS | |||||
| TestEditBooks - test_typeahead_series | PASS | |||||
| TestEditBooks - test_typeahead_tag | PASS | |||||
| TestEditBooks - test_upload_book_cb7 | PASS | |||||
| TestEditBooks - test_upload_book_cbr | PASS | |||||
| TestEditBooks - test_upload_book_cbt | PASS | |||||
| TestEditBooks - test_upload_book_cbz | PASS | |||||
| TestEditBooks - test_upload_book_epub | PASS | |||||
| TestEditBooks - test_upload_book_fb2 | PASS | |||||
| TestEditBooks - test_upload_book_lit | PASS | |||||
| TestEditBooks - test_upload_book_mobi | PASS | |||||
| TestEditBooks - test_upload_book_pdf | PASS | |||||
| TestEditBooks - test_upload_cbz_coverformats | PASS | |||||
| TestEditBooks - test_upload_cover_hdd | PASS | |||||
| TestEditAuthors | 6 | 6 | 0 | 0 | 0 | Detail | 
| TestEditAuthors - test_change_capital_co_author | PASS | |||||
| TestEditAuthors - test_change_capital_one_author_one_book | PASS | |||||
| TestEditAuthors - test_change_capital_one_author_two_books | PASS | |||||
| TestEditAuthors - test_change_capital_rename_co_author | PASS | |||||
| TestEditAuthors - test_change_capital_rename_two_co_authors | PASS | |||||
| TestEditAuthors - test_rename_capital_on_upload | PASS | |||||
| TestEditBooksList | 18 | 18 | 0 | 0 | 0 | Detail | 
| TestEditBooksList - test_bookslist_edit_author | PASS | |||||
| TestEditBooksList - test_bookslist_edit_categories | PASS | |||||
| TestEditBooksList - test_bookslist_edit_comment | PASS | |||||
| TestEditBooksList - test_bookslist_edit_cust_category | PASS | |||||
| TestEditBooksList - test_bookslist_edit_cust_comment | PASS | |||||
| TestEditBooksList - test_bookslist_edit_cust_enum | PASS | |||||
| TestEditBooksList - test_bookslist_edit_cust_float | PASS | |||||
| TestEditBooksList - test_bookslist_edit_cust_int | PASS | |||||
| TestEditBooksList - test_bookslist_edit_cust_ratings | PASS | |||||
| TestEditBooksList - test_bookslist_edit_cust_text | PASS | |||||
| TestEditBooksList - test_bookslist_edit_languages | PASS | |||||
| TestEditBooksList - test_bookslist_edit_publisher | PASS | |||||
| TestEditBooksList - test_bookslist_edit_series | PASS | |||||
| TestEditBooksList - test_bookslist_edit_seriesindex | PASS | |||||
| TestEditBooksList - test_bookslist_edit_title | PASS | |||||
| TestEditBooksList - test_list_visibility | PASS | |||||
| TestEditBooksList - test_restricted_rights | PASS | |||||
| TestEditBooksList - test_search_books_list | PASS | |||||
| TestLoadMetadata | 1 | 0 | 0 | 1 | 0 | Detail | 
| TestLoadMetadata - test_load_metadata | Traceback (most recent call last):
  File "/home/ozzie/Development/calibre-web-test/test/test_edit_books_metadata.py", line 90, in test_load_metadata
    elif 'https://amazon.com/' == results[20]['source']:
IndexError: list index out of range | |||||
| TestLoadMetadataScholar | 1 | 1 | 0 | 0 | 0 | Detail | 
| TestLoadMetadataScholar - test_load_metadata | PASS | |||||
| TestSTARTTLS | 3 | 3 | 0 | 0 | 0 | Detail | 
| TestSTARTTLS - test_STARTTLS | PASS | |||||
| TestSTARTTLS - test_STARTTLS_SSL_setup_error | PASS | |||||
| TestSTARTTLS - test_STARTTLS_resend_password | PASS | |||||
| TestSSL | 7 | 7 | 0 | 0 | 0 | Detail | 
| TestSSL - test_SSL_None_setup_error | PASS | |||||
| TestSSL - test_SSL_STARTTLS_setup_error | PASS | |||||
| TestSSL - test_SSL_logging_email | PASS | |||||
| TestSSL - test_SSL_non_admin_user | PASS | |||||
| TestSSL - test_SSL_only | PASS | |||||
| TestSSL - test_email_limit | PASS | |||||
| TestSSL - test_filepicker_two_file | PASS | |||||
| TestEmbedMetadata | 5 | 5 | 0 | 0 | 0 | Detail | 
| TestEmbedMetadata - test_convert_file_embed_metadata | PASS | |||||
| TestEmbedMetadata - test_convert_kepub_embed_metadata | PASS | |||||
| TestEmbedMetadata - test_download_check_metadata | PASS | |||||
| TestEmbedMetadata - test_download_kepub_embed_metadata | PASS | |||||
| TestEmbedMetadata - test_download_permissions_missing_file | PASS | |||||
| TestBookDatabase | 1 | 1 | 0 | 0 | 0 | Detail | 
| TestBookDatabase - test_invalid_book_path | PASS | |||||
| TestErrorReadColumn | 2 | 2 | 0 | 0 | 0 | Detail | 
| TestErrorReadColumn - test_invalid_custom_column | PASS | |||||
| TestErrorReadColumn - test_invalid_custom_read_column | PASS | |||||
| TestFilePicker | 3 | 2 | 0 | 0 | 1 | Detail | 
| TestFilePicker - test_filepicker_limited_file | PASS | |||||
| TestFilePicker - test_filepicker_new_file | ||||||
| TestFilePicker - test_two_filepickers | PASS | |||||
| TestSetupGdrive | 1 | 1 | 0 | 0 | 0 | Detail | 
| TestSetupGdrive - test_config_gdrive | PASS | |||||
| TestGoodreads | 3 | 3 | 0 | 0 | 0 | Detail | 
| TestGoodreads - test_author_page | PASS | |||||
| TestGoodreads - test_author_page_invalid | PASS | |||||
| TestGoodreads - test_goodreads_about | PASS | |||||
| TestKoboSync | 12 | 10 | 0 | 2 | 0 | Detail | 
| TestKoboSync - test_book_download | Traceback (most recent call last):
  File "/home/ozzie/Development/calibre-web-test/test/test_kobo_sync.py", line 617, in test_book_download
    self.assertGreaterEqual(2, len(data[0]['NewEntitlement']['BookMetadata']['DownloadUrls']), data)
TypeError: 'NoneType' object is not subscriptable | |||||
| TestKoboSync - test_kobo_about | PASS | |||||
| TestKoboSync - test_kobo_limit | PASS | |||||
| TestKoboSync - test_kobo_no_download | PASS | |||||
| TestKoboSync - test_kobo_sync_selected_shelfs | PASS | |||||
| TestKoboSync - test_shelves_add_remove_books | PASS | |||||
| TestKoboSync - test_sync_changed_book | PASS | |||||
| TestKoboSync - test_sync_invalid | PASS | |||||
| TestKoboSync - test_sync_reading_state | PASS | |||||
| TestKoboSync - test_sync_shelf | PASS | |||||
| TestKoboSync - test_sync_unchanged | PASS | |||||
| TestKoboSync - test_sync_upload | Traceback (most recent call last):
  File "/home/ozzie/Development/calibre-web-test/test/test_kobo_sync.py", line 281, in test_sync_upload
    upload.send_keys(upload_file)
AttributeError: 'bool' object has no attribute 'send_keys' | |||||
| TestKoboSyncBig | 6 | 6 | 0 | 0 | 0 | Detail | 
| TestKoboSyncBig - test_download_cover | PASS | |||||
| TestKoboSyncBig - test_kobo_sync_multi_user | PASS | |||||
| TestKoboSyncBig - test_kobo_sync_selected_shelves | PASS | |||||
| TestKoboSyncBig - test_sync_changed_book | PASS | |||||
| TestKoboSyncBig - test_sync_reading_state | PASS | |||||
| TestKoboSyncBig - test_sync_shelf | PASS | |||||
| TestLdapLogin | 13 | 13 | 0 | 0 | 0 | Detail | 
| TestLdapLogin - test_LDAP_SSL | PASS | |||||
| TestLdapLogin - test_LDAP_SSL_CERTIFICATE | PASS | |||||
| TestLdapLogin - test_LDAP_STARTTLS | PASS | |||||
| TestLdapLogin - test_LDAP_fallback_Login | PASS | |||||
| TestLdapLogin - test_LDAP_import | PASS | |||||
| TestLdapLogin - test_LDAP_import_memberfield | PASS | |||||
| TestLdapLogin - test_LDAP_login | PASS | |||||
| TestLdapLogin - test_invalid_LDAP | PASS | |||||
| TestLdapLogin - test_ldap_about | PASS | |||||
| TestLdapLogin - test_ldap_authentication | PASS | |||||
| TestLdapLogin - test_ldap_kobo_sync | PASS | |||||
| TestLdapLogin - test_ldap_opds_anonymous | PASS | |||||
| TestLdapLogin - test_ldap_opds_download_book | PASS | |||||
| TestSecurity | 4 | 4 | 0 | 0 | 0 | Detail | 
| TestSecurity - test_login_limit | PASS | |||||
| TestSecurity - test_opds_limit | PASS | |||||
| TestSecurity - test_password_strength | PASS | |||||
| TestSecurity - test_register_limit | PASS | |||||
| TestCalibreWebListOrders | 10 | 10 | 0 | 0 | 0 | Detail | 
| TestCalibreWebListOrders - test_author_sort | PASS | |||||
| TestCalibreWebListOrders - test_download_sort | PASS | |||||
| TestCalibreWebListOrders - test_format_sort | PASS | |||||
| TestCalibreWebListOrders - test_lang_sort | PASS | |||||
| TestCalibreWebListOrders - test_order_authors_all_links | PASS | |||||
| TestCalibreWebListOrders - test_order_series_all_links | PASS | |||||
| TestCalibreWebListOrders - test_publisher_sort | PASS | |||||
| TestCalibreWebListOrders - test_ratings_sort | PASS | |||||
| TestCalibreWebListOrders - test_series_sort | PASS | |||||
| TestCalibreWebListOrders - test_tags_sort | PASS | |||||
| TestLogging | 9 | 8 | 0 | 0 | 1 | Detail | 
| TestLogging - test_access_log_recover | PASS | |||||
| TestLogging - test_debug_log | PASS | |||||
| TestLogging - test_debuginfo_download | PASS | |||||
| TestLogging - test_failed_login | PASS | |||||
| TestLogging - test_failed_register | ||||||
| TestLogging - test_logbook_download | PASS | |||||
| TestLogging - test_logfile_change | PASS | |||||
| TestLogging - test_logfile_recover | PASS | |||||
| TestLogging - test_logviewer | PASS | |||||
| TestLogin | 19 | 17 | 2 | 0 | 0 | Detail | 
| TestLogin - test_digest_login | PASS | |||||
| TestLogin - test_login_capital_letters_user_unicode_password | PASS | |||||
| TestLogin - test_login_cookie_steal | PASS | |||||
| TestLogin - test_login_delete_admin | PASS | |||||
| TestLogin - test_login_empty_password | PASS | |||||
| TestLogin - test_login_locale_select | PASS | |||||
| TestLogin - test_login_log_hack | Traceback (most recent call last):
  File "/home/ozzie/Development/calibre-web-test/test/test_login.py", line 698, in test_login_log_hack
    self.assertTrue(len(re.findall('Login failed for user "testhackdata"', data)), "Linefeed in username gives wrong loglines")
AssertionError: 0 is not true : Linefeed in username gives wrong loglines | |||||
| TestLogin - test_login_protected | PASS | |||||
| TestLogin - test_login_remember_me | PASS | |||||
| TestLogin - test_login_rename_user | PASS | |||||
| TestLogin - test_login_unicode_user_space_end_password | PASS | |||||
| TestLogin - test_login_user_with_space_password_end_space | PASS | |||||
| TestLogin - test_magic_remote_login | PASS | |||||
| TestLogin - test_next | PASS | |||||
| TestLogin - test_password_policy | PASS | |||||
| TestLogin - test_proxy_login | PASS | |||||
| TestLogin - test_proxy_login_multi_user | Traceback (most recent call last):
  File "/home/ozzie/Development/calibre-web-test/test/test_login.py", line 531, in test_proxy_login_multi_user
    self.assertTrue('<input type="text" class="form-control" name="name" id="name" value="new_user1" autocomplete="off">' in resp.text)
AssertionError: False is not true | |||||
| TestLogin - test_proxy_login_opds | PASS | |||||
| TestLogin - test_robots | PASS | |||||
| TestMergeBooksList | 2 | 2 | 0 | 0 | 0 | Detail | 
| TestMergeBooksList - test_book_merge | PASS | |||||
| TestMergeBooksList - test_delete_book | PASS | |||||
| TestOAuthLogin | 2 | 2 | 0 | 0 | 0 | Detail | 
| TestOAuthLogin - test_oauth_about | PASS | |||||
| TestOAuthLogin - test_visible_oauth | PASS | |||||
| TestOPDSFeed | 24 | 24 | 0 | 0 | 0 | Detail | 
| TestOPDSFeed - test_opds | PASS | |||||
| TestOPDSFeed - test_opds_author | PASS | |||||
| TestOPDSFeed - test_opds_books | PASS | |||||
| TestOPDSFeed - test_opds_calibre_companion | PASS | |||||
| TestOPDSFeed - test_opds_colon_password | PASS | |||||
| TestOPDSFeed - test_opds_cover | PASS | |||||
| TestOPDSFeed - test_opds_download_book | PASS | |||||
| TestOPDSFeed - test_opds_formats | PASS | |||||
| TestOPDSFeed - test_opds_guest_user | PASS | |||||
| TestOPDSFeed - test_opds_hot | PASS | |||||
| TestOPDSFeed - test_opds_language | PASS | |||||
| TestOPDSFeed - test_opds_non_admin | PASS | |||||
| TestOPDSFeed - test_opds_publisher | PASS | |||||
| TestOPDSFeed - test_opds_random | PASS | |||||
| TestOPDSFeed - test_opds_ratings | PASS | |||||
| TestOPDSFeed - test_opds_read_unread | PASS | |||||
| TestOPDSFeed - test_opds_search | PASS | |||||
| TestOPDSFeed - test_opds_series | PASS | |||||
| TestOPDSFeed - test_opds_shelf_access | PASS | |||||
| TestOPDSFeed - test_opds_stats | PASS | |||||
| TestOPDSFeed - test_opds_tags | PASS | |||||
| TestOPDSFeed - test_opds_top_rated | PASS | |||||
| TestOPDSFeed - test_opds_unicode_user | PASS | |||||
| TestOPDSFeed - test_recently_added | PASS | |||||
| TestUploadPDF | 1 | 1 | 0 | 0 | 0 | Detail | 
| TestUploadPDF - test_upload_invalid_pdf | PASS | |||||
| TestPipInstall | 3 | 3 | 0 | 0 | 0 | Detail | 
| TestPipInstall - test_command_start | PASS | |||||
| TestPipInstall - test_foldername_database_location | PASS | |||||
| TestPipInstall - test_module_start | PASS | |||||
| TestReader | 8 | 7 | 0 | 0 | 1 | Detail | 
| TestReader - test_cb7_reader | SKIP | |||||
| TestReader - test_comic_MACOS_files | PASS | |||||
| TestReader - test_comic_reader | PASS | |||||
| TestReader - test_epub_reader | PASS | |||||
| TestReader - test_pdf_reader | PASS | |||||
| TestReader - test_single_file_comic | PASS | |||||
| TestReader - test_sound_listener | PASS | |||||
| TestReader - test_txt_reader | PASS | |||||
| TestReadOnlyDatabase | 1 | 1 | 0 | 0 | 0 | Detail | 
| TestReadOnlyDatabase - test_readonly_path | PASS | |||||
| TestRegister | 8 | 8 | 0 | 0 | 0 | Detail | 
| TestRegister - test_forgot_password | PASS | |||||
| TestRegister - test_illegal_email | PASS | |||||
| TestRegister - test_limit_domain | PASS | |||||
| TestRegister - test_register_no_server | PASS | |||||
| TestRegister - test_registering_only_email | PASS | |||||
| TestRegister - test_registering_user | PASS | |||||
| TestRegister - test_registering_user_fail | PASS | |||||
| TestRegister - test_user_change_password | PASS | |||||
| TestReverseProxy | 3 | 3 | 0 | 0 | 0 | Detail | 
| TestReverseProxy - test_logout | PASS | |||||
| TestReverseProxy - test_move_page | PASS | |||||
| TestReverseProxy - test_reverse_about | PASS | |||||
| TestShelf | 16 | 15 | 0 | 0 | 1 | Detail | 
| TestShelf - test_access_shelf | PASS | |||||
| TestShelf - test_add_shelf_from_search | PASS | |||||
| TestShelf - test_adv_search_shelf | PASS | |||||
| TestShelf - test_arrange_shelf | PASS | |||||
| TestShelf - test_create_public_shelf | PASS | |||||
| TestShelf - test_create_public_shelf_no_permission | PASS | |||||
| TestShelf - test_delete_book_of_shelf | PASS | |||||
| TestShelf - test_private_shelf | PASS | |||||
| TestShelf - test_public_private_shelf | PASS | |||||
| TestShelf - test_public_shelf | PASS | |||||
| TestShelf - test_rename_shelf | PASS | |||||
| TestShelf - test_shelf_action_non_shelf_edit_role | PASS | |||||
| TestShelf - test_shelf_anonymous | PASS | |||||
| TestShelf - test_shelf_database_change | ||||||
| TestShelf - test_shelf_long_name | PASS | |||||
| TestShelf - test_xss_shelf | PASS | |||||
| TestSocket | 1 | 1 | 0 | 0 | 0 | Detail | 
| TestSocket - test_socket_communication | PASS | |||||
| TestSystemdActivation | 1 | 1 | 0 | 0 | 0 | Detail | 
| TestSystemdActivation - test_systemd_activation | PASS | |||||
| TestThumbnailsEnv | 1 | 1 | 0 | 0 | 0 | Detail | 
| TestThumbnailsEnv - test_cover_cache_env_on_database_change | PASS | |||||
| TestThumbnails | 8 | 7 | 0 | 0 | 1 | Detail | 
| TestThumbnails - test_cache_non_writable | PASS | |||||
| TestThumbnails - test_cache_of_deleted_book | PASS | |||||
| TestThumbnails - test_cover_cache_on_database_change | PASS | |||||
| TestThumbnails - test_cover_change_on_upload_new_cover | PASS | |||||
| TestThumbnails - test_cover_for_series | SKIP | |||||
| TestThumbnails - test_cover_on_upload_book | PASS | |||||
| TestThumbnails - test_remove_cover_from_cache | PASS | |||||
| TestThumbnails - test_sideloaded_book | PASS | |||||
| TestUploadEPubs | 6 | 6 | 0 | 0 | 0 | Detail | 
| TestUploadEPubs - test_upload_epub_comments | PASS | |||||
| TestUploadEPubs - test_upload_epub_cover | PASS | |||||
| TestUploadEPubs - test_upload_epub_cover_formats | PASS | |||||
| TestUploadEPubs - test_upload_epub_duplicate | PASS | |||||
| TestUploadEPubs - test_upload_epub_identifier | PASS | |||||
| TestUploadEPubs - test_upload_epub_lang | PASS | |||||
| TestUserList | 18 | 18 | 0 | 0 | 0 | Detail | 
| TestUserList - test_edit_user_email | PASS | |||||
| TestUserList - test_list_visibility | PASS | |||||
| TestUserList - test_user_list_admin_role | PASS | |||||
| TestUserList - test_user_list_check_sort | PASS | |||||
| TestUserList - test_user_list_denied_tags | PASS | |||||
| TestUserList - test_user_list_download_role | PASS | |||||
| TestUserList - test_user_list_edit_button | PASS | |||||
| TestUserList - test_user_list_edit_email | PASS | |||||
| TestUserList - test_user_list_edit_kindle | PASS | |||||
| TestUserList - test_user_list_edit_language | PASS | |||||
| TestUserList - test_user_list_edit_locale | PASS | |||||
| TestUserList - test_user_list_edit_name | PASS | |||||
| TestUserList - test_user_list_edit_visiblility | PASS | |||||
| TestUserList - test_user_list_guest_edit | PASS | |||||
| TestUserList - test_user_list_remove_admin | PASS | |||||
| TestUserList - test_user_list_requests | PASS | |||||
| TestUserList - test_user_list_search | PASS | |||||
| TestUserList - test_user_list_sort | PASS | |||||
| TestUserLoad | 1 | 1 | 0 | 0 | 0 | Detail | 
| TestUserLoad - test_user_change_vis | PASS | |||||
| TestUserTemplate | 21 | 21 | 0 | 0 | 0 | Detail | 
| TestUserTemplate - test_allow_column_restriction | PASS | |||||
| TestUserTemplate - test_allow_tag_restriction | PASS | |||||
| TestUserTemplate - test_archived_format_template | PASS | |||||
| TestUserTemplate - test_author_user_template | PASS | |||||
| TestUserTemplate - test_best_user_template | PASS | |||||
| TestUserTemplate - test_category_user_template | PASS | |||||
| TestUserTemplate - test_deny_column_restriction | PASS | |||||
| TestUserTemplate - test_deny_tag_restriction | PASS | |||||
| TestUserTemplate - test_detail_random_user_template | PASS | |||||
| TestUserTemplate - test_download_user_template | PASS | |||||
| TestUserTemplate - test_format_user_template | PASS | |||||
| TestUserTemplate - test_hot_user_template | PASS | |||||
| TestUserTemplate - test_language_user_template | PASS | |||||
| TestUserTemplate - test_limit_book_languages | PASS | |||||
| TestUserTemplate - test_list_user_template | PASS | |||||
| TestUserTemplate - test_publisher_user_template | PASS | |||||
| TestUserTemplate - test_random_user_template | PASS | |||||
| TestUserTemplate - test_read_user_template | PASS | |||||
| TestUserTemplate - test_recent_user_template | PASS | |||||
| TestUserTemplate - test_series_user_template | PASS | |||||
| TestUserTemplate - test_ui_language_settings | PASS | |||||
| TestCalibreWebVisibilitys | 35 | 35 | 0 | 0 | 0 | Detail | 
| TestCalibreWebVisibilitys - test_about | PASS | |||||
| TestCalibreWebVisibilitys - test_admin_SMTP_Settings | PASS | |||||
| TestCalibreWebVisibilitys - test_admin_add_user | PASS | |||||
| TestCalibreWebVisibilitys - test_admin_change_password | PASS | |||||
| TestCalibreWebVisibilitys - test_admin_change_visibility_archived | PASS | |||||
| TestCalibreWebVisibilitys - test_admin_change_visibility_authors | PASS | |||||
| TestCalibreWebVisibilitys - test_admin_change_visibility_category | PASS | |||||
| TestCalibreWebVisibilitys - test_admin_change_visibility_file_formats | PASS | |||||
| TestCalibreWebVisibilitys - test_admin_change_visibility_hot | PASS | |||||
| TestCalibreWebVisibilitys - test_admin_change_visibility_language | PASS | |||||
| TestCalibreWebVisibilitys - test_admin_change_visibility_publisher | PASS | |||||
| TestCalibreWebVisibilitys - test_admin_change_visibility_random | PASS | |||||
| TestCalibreWebVisibilitys - test_admin_change_visibility_rated | PASS | |||||
| TestCalibreWebVisibilitys - test_admin_change_visibility_rating | PASS | |||||
| TestCalibreWebVisibilitys - test_admin_change_visibility_read | PASS | |||||
| TestCalibreWebVisibilitys - test_admin_change_visibility_series | PASS | |||||
| TestCalibreWebVisibilitys - test_allow_columns | PASS | |||||
| TestCalibreWebVisibilitys - test_allow_tags | PASS | |||||
| TestCalibreWebVisibilitys - test_archive_books | PASS | |||||
| TestCalibreWebVisibilitys - test_authors_max_settings | PASS | |||||
| TestCalibreWebVisibilitys - test_change_title | PASS | |||||
| TestCalibreWebVisibilitys - test_checked_logged_in | PASS | |||||
| TestCalibreWebVisibilitys - test_hide_custom_column | PASS | |||||
| TestCalibreWebVisibilitys - test_link_column_to_read_status | PASS | |||||
| TestCalibreWebVisibilitys - test_random_books_available | PASS | |||||
| TestCalibreWebVisibilitys - test_read_status_visible | PASS | |||||
| TestCalibreWebVisibilitys - test_request_link_column_to_read_status | PASS | |||||
| TestCalibreWebVisibilitys - test_restrict_columns | PASS | |||||
| TestCalibreWebVisibilitys - test_restrict_tags | PASS | |||||
| TestCalibreWebVisibilitys - test_save_views_recent | PASS | |||||
| TestCalibreWebVisibilitys - test_search_functions | PASS | |||||
| TestCalibreWebVisibilitys - test_search_order | PASS | |||||
| TestCalibreWebVisibilitys - test_search_string | PASS | |||||
| TestCalibreWebVisibilitys - test_user_email_available | PASS | |||||
| TestCalibreWebVisibilitys - test_user_visibility_sidebar | PASS | |||||
| TestCalibreHelper | 16 | 16 | 0 | 0 | 0 | Detail | 
| TestCalibreHelper - test_author_sort | PASS | |||||
| TestCalibreHelper - test_author_sort_comma | PASS | |||||
| TestCalibreHelper - test_author_sort_junior | PASS | |||||
| TestCalibreHelper - test_author_sort_oneword | PASS | |||||
| TestCalibreHelper - test_author_sort_roman | PASS | |||||
| TestCalibreHelper - test_check_Limit_Length | PASS | |||||
| TestCalibreHelper - test_check_char_replacement | PASS | |||||
| TestCalibreHelper - test_check_chinese_Characters | PASS | |||||
| TestCalibreHelper - test_check_deg_eur_replacement | PASS | |||||
| TestCalibreHelper - test_check_doubleS | PASS | |||||
| TestCalibreHelper - test_check_finish_Dot | PASS | |||||
| TestCalibreHelper - test_check_high23 | PASS | |||||
| TestCalibreHelper - test_check_umlauts | PASS | |||||
| TestCalibreHelper - test_random_password | PASS | |||||
| TestCalibreHelper - test_split_authors | PASS | |||||
| TestCalibreHelper - test_whitespaces | PASS | |||||
| Total | 433 | 408 | 4 | 12 | 9 | |
| Program library | Installed Version | Test class | 
|---|---|---|
| Platform | Linux 6.5.0-14-generic #14~22.04.1-Ubuntu SMP PREEMPT_DYNAMIC Mon Nov 20 18:15:30 UTC 2 x86_64 x86_64 | Basic | 
| Python | 3.10.12 | Basic | 
| advocate | 1.0.0 | Basic | 
| APScheduler | 3.10.4 | Basic | 
| Babel | 2.14.0 | Basic | 
| chardet | 4.0.0 | Basic | 
| Flask | 2.3.3 | Basic | 
| flask-babel | 4.0.0 | Basic | 
| Flask-Limiter | 3.5.0 | Basic | 
| Flask-Login | 0.6.2 | Basic | 
| Flask-Principal | 0.4.0 | Basic | 
| Flask-WTF | 1.2.1 | Basic | 
| greenlet | 3.0.3 | Basic | 
| iso-639 | 0.4.5 | Basic | 
| Jinja2 | 3.1.3 | Basic | 
| lxml | 4.9.4 | Basic | 
| pyasn1 | 0.5.1 | Basic | 
| pypdf | 3.15.5 | Basic | 
| pytz | 2023.3.post1 | Basic | 
| requests | 2.31.0 | Basic | 
| SQLAlchemy | 2.0.25 | Basic | 
| tornado | 6.3.3 | Basic | 
| Unidecode | 1.3.8 | Basic | 
| Wand | 0.6.13 | Basic | 
| Werkzeug | 2.3.8 | Basic | 
| google-api-python-client | 2.113.0 | TestBackupMetadataGdrive | 
| httplib2 | 0.22.0 | TestBackupMetadataGdrive | 
| oauth2client | 4.1.3 | TestBackupMetadataGdrive | 
| PyDrive2 | 1.19.0 | TestBackupMetadataGdrive | 
| PyYAML | 6.0.1 | TestBackupMetadataGdrive | 
| google-api-python-client | 2.113.0 | TestCliGdrivedb | 
| httplib2 | 0.22.0 | TestCliGdrivedb | 
| oauth2client | 4.1.3 | TestCliGdrivedb | 
| PyDrive2 | 1.19.0 | TestCliGdrivedb | 
| PyYAML | 6.0.1 | TestCliGdrivedb | 
| google-api-python-client | 2.113.0 | TestEbookConvertCalibreGDrive | 
| httplib2 | 0.22.0 | TestEbookConvertCalibreGDrive | 
| oauth2client | 4.1.3 | TestEbookConvertCalibreGDrive | 
| PyDrive2 | 1.19.0 | TestEbookConvertCalibreGDrive | 
| PyYAML | 6.0.1 | TestEbookConvertCalibreGDrive | 
| google-api-python-client | 2.113.0 | TestEbookConvertGDriveKepubify | 
| httplib2 | 0.22.0 | TestEbookConvertGDriveKepubify | 
| oauth2client | 4.1.3 | TestEbookConvertGDriveKepubify | 
| PyDrive2 | 1.19.0 | TestEbookConvertGDriveKepubify | 
| PyYAML | 6.0.1 | TestEbookConvertGDriveKepubify | 
| comicapi | 3.2.0 | TestEditAdditionalBooks | 
| py7zr | 0.20.8 | TestEditAdditionalBooks | 
| rarfile | 4.1 | TestEditAdditionalBooks | 
| py7zr | 0.20.8 | TestEditBooks | 
| google-api-python-client | 2.113.0 | TestEditAuthorsGdrive | 
| httplib2 | 0.22.0 | TestEditAuthorsGdrive | 
| oauth2client | 4.1.3 | TestEditAuthorsGdrive | 
| PyDrive2 | 1.19.0 | TestEditAuthorsGdrive | 
| PyYAML | 6.0.1 | TestEditAuthorsGdrive | 
| beautifulsoup4 | 4.12.2 | TestLoadMetadata | 
| google-api-python-client | 2.113.0 | TestEditBooksOnGdrive | 
| httplib2 | 0.22.0 | TestEditBooksOnGdrive | 
| oauth2client | 4.1.3 | TestEditBooksOnGdrive | 
| PyDrive2 | 1.19.0 | TestEditBooksOnGdrive | 
| PyYAML | 6.0.1 | TestEditBooksOnGdrive | 
| beautifulsoup4 | 4.12.2 | TestLoadMetadataScholar | 
| scholarly | 1.7.11 | TestLoadMetadataScholar | 
| google-api-python-client | 2.113.0 | TestEmbedMetadataGdrive | 
| httplib2 | 0.22.0 | TestEmbedMetadataGdrive | 
| oauth2client | 4.1.3 | TestEmbedMetadataGdrive | 
| PyDrive2 | 1.19.0 | TestEmbedMetadataGdrive | 
| PyYAML | 6.0.1 | TestEmbedMetadataGdrive | 
| google-api-python-client | 2.113.0 | TestSetupGdrive | 
| httplib2 | 0.22.0 | TestSetupGdrive | 
| oauth2client | 4.1.3 | TestSetupGdrive | 
| PyDrive2 | 1.19.0 | TestSetupGdrive | 
| PyYAML | 6.0.1 | TestSetupGdrive | 
| goodreads | 0.3.2 | TestGoodreads | 
| python-Levenshtein | 0.23.0 | TestGoodreads | 
| jsonschema | 4.20.0 | TestKoboSync | 
| jsonschema | 4.20.0 | TestKoboSyncBig | 
| Flask-SimpleLDAP | 1.4.0 | TestLdapLogin | 
| jsonschema | 4.20.0 | TestLdapLogin | 
| python-ldap | 3.4.4 | TestLdapLogin | 
| Flask-Dance | 7.0.1 | TestOAuthLogin | 
| SQLAlchemy-Utils | 0.41.1 | TestOAuthLogin |