Changelog for CPAN-Testers-Schema

0.027     2024-04-27 09:49:52+01:00 Europe/Lisbon

  - Fixed relationship between dists and stat rows
  - Added unique constraint on cpan uploads table
  - Added provisional uploads records when missing while processing
    report

0.026     2024-04-25 15:15:16+01:00 Europe/Lisbon

  [Added]

  - Added method to get latest versions of dists
  - Added relationship to get stat rows for dists
  - Combined, I can now get stat rows for latest versions of dists!

0.025     2020-01-13 21:13:16-05:00 America/New_York

    [Added]

    - Added full report fetching to the fetch command. Now you can
      populate an entire local database using the API!
    - Added a resultset method to get recent uploads to CPAN.
    - Added a relationship from a CPAN release to its report metrics
      (pass/fail/na/unknown counts) to make fetching those metrics easy.
    - Added a method to total up all release metrics by dist/version. We
      store metrics based on other criteria (stable/dev perl, for
      example), so we need to be able to collate them.
    - Added accessor methods for common parts of the test report to both
      the TestReport and Stats objects. These two objects have the same
      API now, so one can be substituted for the other with little
      difference (except the Stats object lacks the full text of the
      report).

    [Fixed]

    - Fixed cpantesters-schema command for the initial deploy. The
      workaround for the primary database is no longer necessary.
    - Fixed the "fetch" command script's options parsing and added
      better error checking from the API.
    - Fixed duplicate test summaries being created for the same report.

0.024     2019-04-27 15:58:52+01:00 Europe/London

    [Added]

    - Added 'cpantesters-schema fetch' command to download data from the
      public API to populate a local database. This can be used for
      testing purposes, but also to get a local copy of data for
      reporting purposes.

    [Fixed]

    - 'cpantesters-schema upgrade' command will now try to install the
      database if it is not already installed. This makes it suitable
      for use in an auto-deploy script.

0.023     2018-08-23 20:32:28-05:00 America/Chicago

    [Added]

    - Added a `version` argument to release resultsets to filter
      per-release summary data by dist _and_version.
    - Added classes for the Perl version metadata tables. These classes
      allow access to the `perl_version` table which stores metadata
      about known Perl 5 releases.
    - Added method to search for test summary rows by the Perl maturity

    [Fixed]

    - Fixed "patch" Perls to be considered "development" Perls. This is
      how the existing site and backend treats them, even though the two
      flags are different. "Patch" Perls are changed from the official
      P5P releases, and should therefore be treated differently.
    - Fixed Travis config to use MySQL 5.7. This MySQL version is
      required for the tests to run. Thanks @paultcochrane [Github #21]
    - Fixed "created" date in test reports being set to impossible
      values. We were allowing this to come from reporters, but we want
      this to be the time that we got the report. Later, if we want, we
      can add another field for when the reporter claims to have created
      the report. [Github #19]

0.022     2018-04-19 14:26:24+02:00 Europe/Oslo

    [Added]

    - Added support for `since` in Stats resultset

0.021     2017-11-28 13:43:34-06:00 America/Chicago

    - Implement support for `maturity` search param for Release queries.

0.020     2017-11-18 20:44:13-06:00 America/Chicago

    [Changed]

    - Added some additional logging to some resultset methods to try to
      track down some problems.

    [Fixed]

    - Fixed issue deserializing JSON from MySQL with illegal ASCII
      control characters inside.

0.019     2017-08-18 12:16:21-05:00 America/Chicago

    [Fixed]

    - Fix exception thrown when searching for the right test author
      details while inserting Metabase facts. SQLite supports `-col` to
      sort by `col` descending, but MySQL doesn't. DBIx::Class let
      `-col` through just fine though. Using the proper DBIx::Class
      syntax for descending order fixes the problem.

    - Allow updating test reports from Metabase facts. Metabase
      clients may submit a fact multiple times, so we need to update the
      test report if it already exists.

    - The test report JSON column is now safe for Latin-1-encoded
      tables. Any UTF-8 characters will be transformed into their
      `\u####` escape sequence. This is a stopgap until this data can be
      moved to a proper UTF-8-encoded table.

    - Metabase facts being translated to new test report format no
      longer allow "v" in front of the Perl version. It's not part of
      the Perl version number and all existing data lacks it.

0.018     2017-08-05 12:42:52-05:00 America/Chicago

    [Fixed]

    - Fixed name of "guid" unique constraint on Stats table. By default,
      DBIx::Class uses the name of the table (cpanstats) in the
      constraint name, but this makes it harder for that name to change
      in the future. Now the name of the constraint is just "guid".

    [Added]

    - Allow test reports to be re-processed. If a test report has
      already been processed (based on its guid), the Stats entry will
      be updated.

0.017     2017-08-04 14:06:17-05:00 America/Chicago

    [Fixed]

    - Fixed some POD formatting issues in the Stats result class. Thanks
      @manwar!

    - Added the correct dependency declaration for Data::UUID, which was
      causing Travis tests to fail. Thanks @manwar!

0.016     2017-08-03 21:38:38-05:00 America/Chicago

    [Fixed]

    - Fixed old schema version with incorrect size of field. Since these
      old tables aren't put through an ALTER TABLE process, we can edit
      the original versions without triggering an upgrade. This means we
      can do minor adjustments to match reality without major problems.

0.015     2017-07-08 12:07:35-05:00 America/Chicago

    [Fixed]

    - Fixed test that starts a MySQL server to run JSON pointer tests.
      JSON support was added in MySQL 5.7, and cannot run on any MySQL
      prior to that. Now the tests check that the MySQL is the right
      version before continuing.

0.014     2017-07-06 22:56:21-05:00 America/Chicago

    [Added]

    - Added method to search full test reports for language,
      distribution, and version

0.013     2017-05-26 22:48:55-05:00 America/Chicago

    [Added]

    - Added a method to get the CPAN upload from a test report

0.012     2017-05-14 15:56:39+02:00 Europe/Paris

    [Fixed]

    - Fixed upgrade for brand-new SQLite databases

    [Added]

    - Added a method to translate from test report JSON documents to the
      main Stats table. Thanks @jberger!

0.011     2017-05-14 15:50:18+02:00 Europe/Paris

    [Added]

    - Added cpantesters-schema install to custom DSN. This allows me to
      build a custom SQLite database for local testing.
    - Added a SQLite schema deployment strategy. This should make
      testing a bit easier.

0.010     2017-05-14 10:30:48+02:00 Europe/Paris

    [Fixed]

    - Fixed date/time format handling for TestReport created field. We
      need to make sure that the date/time is formatted correctly for
      the given database engine. The "created" date/time in the report
      is always a full ISO8601 date/time.

0.009     2017-05-13 14:42:38+02:00 Europe/Paris

    [Fixed]

    - Changed Metabase -> TestReport migration for new test report
      format, which moves the test result into a top-level "result" key.

0.008     2017-05-13 10:53:47+02:00 Europe/Paris

    [Fixed]

    - Updated metabase users table to add unique constraint to user
      GUID. The source table has multiple mappings for a single user,
      but as @bingos pointed out: This means that some e-mails for
      a user are completely inaccurate, bordering on malicious (since
      authors cannot get in touch with testers). The new table has only
      one mapping per GUID, and we can then update that mapping if
      a tester complains.

0.007     2017-05-12 17:52:23+02:00 Europe/Paris

    [Added]

    - Add a "created" field to the TestReport table to keep track of
      when the test report was created
    - Auto serialize the TestReport to/from JSON
    - Add the ID and created date/time to the JSON test report
    - Add a table to hold the old Metabase user information so we can
      find name/email for legacy clients
    - Add a conversion method from Metabase::Fact to the new test
      report. This allows legacy clients to send in Metabase reports and
      be updated to the new test report format.


0.006     2017-05-12 10:02:58+02:00 Europe/Paris

    [Added]

    - TestReport table for storing new test reports as JSON documents
    - cpantesters-schema script for deploying the new database schema
      [Github #2]
    - Add `updated` column to raw test reports to keep track of when
      they were updated

    [Fixed]

    - Fixed all the MySQL foreign key constraints. Foreign key columns
      need to be exactly the same column type as their foreign
      counterpart.

0.005     2016-12-11 00:36:54-06:00 America/Chicago

    [Fixed]

    - Fixed dependency declaration for DateTime and
      DateTime::Format::ISO8601

0.004     2016-12-10 02:45:36-06:00 America/Chicago

    [Fixed]

    - Properly inflate CPAN upload `released` column into a DateTime
      object. This makes for a better API so that we can, eventually,
      change the data type from epoch timestamp to ISO8601 date/time.

0.003     2016-12-09 19:55:09-06:00 America/Chicago

    [Added]

    - Added CPAN uploads data query module
      (CPAN::Testers::Schema::ResultSet::Upload) to query data from CPAN
      uploads.

    [Other]

    - Switched to DBIx::Class::Candy for cleaner result classes

0.002     2016-11-19 11:53:54-06:00 America/Chicago

    [Added]

    - Added relationship between report statistics and release
      summaries. This relationship can be used to see when the release
      summary was last updated.

    - Added release data query module
      (CPAN::Testers::Schema::ResultSet::Release) for easier querying of
      release data. This will be used to provide summary data for
      metacpan and various CPAN author dashboards.

    [Fixed]

    - Properly enabled all Perl 5.24 features. Since we're relying on
      it, we should be using it to the fullest!

0.001     2016-11-18 15:06:56-06:00 America/Chicago

 - This initial release contains a schema for some tables in the
   `cpanstats` database, with more tables to come later. This release is
   minimal to enable its use in the new CPAN Testers API, coming later.

   Hello from meta::hack 2016 in Chicago!