browsertrix/backend/btrixcloud/operator
Ilya Kreymer 4f676e4e82
QA Runs Initial Backend Implementation (#1586)
Supports running QA Runs via the QA API!

Builds on top of the `issue-1498-crawl-qa-backend-support` branch, fixes
#1498

Also requires the latest Browsertrix Crawler 1.1.0+ (from
webrecorder/browsertrix-crawler#469 branch)

Notable changes:
- QARun objects contain info about QA runs, which are crawls
performed on data loaded from existing crawls.

- Various crawl db operations can be performed on either the crawl or
`qa.` object, and core crawl fields have been moved to CoreCrawlable.

- While running,`QARun` data stored in a single `qa` object, while
finished qa runs are added to `qaFinished` dictionary on the Crawl. The
QA list API returns data from the finished list, sorted by most recent
first.

- Includes additional type fixes / type safety, especially around
BaseCrawl / Crawl / UploadedCrawl functionality, also creating specific
get_upload(), get_basecrawl(), get_crawl() getters for internal use and
get_crawl_out() for API

- Support filtering and sorting pages via `qaFilterBy` (screenshotMatch, textMatch) 
along with `gt`, `lt`, `gte`, `lte` params to return pages based on QA results.

---------
Co-authored-by: Tessa Walsh <tessa@bitarchivist.net>
2024-03-20 22:42:16 -07:00
..
__init__.py Refactor operator class into module (#1564) 2024-02-29 14:40:12 -08:00
baseoperator.py profile browser fixes: better resource usage + load retry (main) (#1604) 2024-03-16 15:07:04 -07:00
bgjobs.py Refactor operator class into module (#1564) 2024-02-29 14:40:12 -08:00
crawls.py QA Runs Initial Backend Implementation (#1586) 2024-03-20 22:42:16 -07:00
cronjobs.py QA Runs Initial Backend Implementation (#1586) 2024-03-20 22:42:16 -07:00
models.py QA Runs Initial Backend Implementation (#1586) 2024-03-20 22:42:16 -07:00
profiles.py Refactor operator class into module (#1564) 2024-02-29 14:40:12 -08:00