← Back to team overview

launchpad-reviewers team mailing list archive

[Merge] lp:~cjwatson/launchpad/db-livefs into lp:launchpad/db-devel

 

You have been requested to review the proposed merge of lp:~cjwatson/launchpad/db-livefs into lp:launchpad/db-devel.

For more details, see:
https://code.launchpad.net/~cjwatson/launchpad/db-livefs/+merge/217206

This is the database part of bug 1247461, to move live filesystem building off their current dedicated builders into the Launchpad build farm.  It models each buildable image configuration as a LiveFS, creates LiveFSBuild as a new kind of BuildFarmJob, and adds a LiveFSFile librarian link table.

I expect to use a garbo job to clear out the bulky uploaded files for all but the most recent N builds for each LiveFS, but we can probably store the log files more or less indefinitely.

-- 
https://code.launchpad.net/~cjwatson/launchpad/db-livefs/+merge/217206
Your team Launchpad code reviewers is requested to review the proposed merge of lp:~cjwatson/launchpad/db-livefs into lp:launchpad/db-devel.
=== added file 'database/schema/patch-2209-56-0.sql'
--- database/schema/patch-2209-56-0.sql	1970-01-01 00:00:00 +0000
+++ database/schema/patch-2209-56-0.sql	2014-04-25 11:16:45 +0000
@@ -0,0 +1,86 @@
+-- Copyright 2014 Canonical Ltd.  This software is licensed under the
+-- GNU Affero General Public License version 3 (see the file LICENSE).
+
+SET client_min_messages=ERROR;
+
+CREATE TABLE LiveFS (
+    id serial PRIMARY KEY,
+    date_created timestamp without time zone DEFAULT (CURRENT_TIMESTAMP AT TIME ZONE 'UTC') NOT NULL,
+    registrant integer NOT NULL REFERENCES person,
+    owner integer NOT NULL REFERENCES person,
+    distroseries integer NOT NULL REFERENCES distroseries,
+    name text NOT NULL,
+    json_data text,
+    CONSTRAINT valid_name CHECK (valid_name(name))
+);
+
+COMMENT ON TABLE LiveFS IS 'A buildable live filesystem image.';
+COMMENT ON COLUMN LiveFS.registrant IS 'The user who registered the live filesystem image.';
+COMMENT ON COLUMN LiveFS.owner IS 'The owner of the live filesystem image.';
+COMMENT ON COLUMN LiveFS.distroseries IS 'The DistroSeries for which the image should be built.';
+COMMENT ON COLUMN LiveFS.name IS 'The name of the live filesystem image, unique per DistroSeries.';
+COMMENT ON COLUMN LiveFS.json_data IS 'A JSON struct containing data for the image build.';
+
+CREATE TABLE LiveFSBuild (
+    id serial PRIMARY KEY,
+    requester integer NOT NULL REFERENCES person,
+    livefs integer NOT NULL REFERENCES livefs,
+    archive integer NOT NULL REFERENCES archive,
+    distroarchseries integer NOT NULL REFERENCES distroarchseries,
+    pocket integer NOT NULL,
+    unique_key text,
+    json_data_override text,
+    processor integer NOT NULL REFERENCES processor,
+    virtualized boolean NOT NULL,
+    date_created timestamp without time zone DEFAULT (CURRENT_TIMESTAMP AT TIME ZONE 'UTC') NOT NULL,
+    date_started timestamp without time zone,
+    date_finished timestamp without time zone,
+    date_first_dispatched timestamp without time zone,
+    builder integer REFERENCES builder,
+    status integer NOT NULL,
+    log integer REFERENCES libraryfilealias,
+    upload_log integer REFERENCES libraryfilealias,
+    dependencies text,
+    failure_count integer DEFAULT 0 NOT NULL,
+    build_farm_job integer NOT NULL REFERENCES buildfarmjob
+);
+
+COMMENT ON TABLE LiveFSBuild IS 'A build record for a live filesystem image.';
+COMMENT ON COLUMN LiveFSBuild.requester IS 'The person who requested this live filesystem image build.';
+COMMENT ON COLUMN LiveFSBuild.livefs IS 'Live filesystem image to build.';
+COMMENT ON COLUMN LiveFSBuild.archive IS 'The archive that the live filesystem image should build from.';
+COMMENT ON COLUMN LiveFSBuild.distroarchseries IS 'The distroarchseries that the live filesystem image should build from.';
+COMMENT ON COLUMN LiveFSBuild.pocket IS 'The pocket that the live filesystem image should build from.';
+COMMENT ON COLUMN LiveFSBuild.unique_key IS 'A unique key distinguishing this build from others for the same livefs/archive/distroarchseries/pocket, or NULL.';
+COMMENT ON COLUMN LiveFSBuild.json_data_override IS 'A JSON struct containing data for the image build, each key of which overrides the same key from livefs.json_data.';
+COMMENT ON COLUMN LiveFSBuild.virtualized IS 'The virtualization setting required by this build farm job.';
+COMMENT ON COLUMN LiveFSBuild.date_created IS 'When the build farm job record was created.';
+COMMENT ON COLUMN LiveFSBuild.date_started IS 'When the build farm job started being processed.';
+COMMENT ON COLUMN LiveFSBuild.date_finished IS 'When the build farm job finished being processed.';
+COMMENT ON COLUMN LiveFSBuild.date_first_dispatched IS 'The instant the build was dispatched the first time.  This value will not get overridden if the build is retried.';
+COMMENT ON COLUMN LiveFSBuild.builder IS 'The builder which processed this build farm job.';
+COMMENT ON COLUMN LiveFSBuild.status IS 'The current build status.';
+COMMENT ON COLUMN LiveFSBuild.log IS 'The log file for this build farm job stored in the librarian.';
+COMMENT ON COLUMN LiveFSBuild.upload_log IS 'The upload log file for this build farm job stored in the librarian.';
+COMMENT ON COLUMN LiveFSBuild.dependencies IS 'A Debian-like dependency line specifying the current missing dependencies for this build.';
+COMMENT ON COLUMN LiveFSBuild.failure_count IS 'The number of consecutive failures on this job.  If excessive, the job may be terminated.';
+COMMENT ON COLUMN LiveFSBuild.build_farm_job IS 'The build farm job with the base information.';
+
+CREATE INDEX livefsbuild__log__idx
+    ON LiveFSBuild (log);
+CREATE INDEX livefsbuild__upload_log__idx
+    ON LiveFSBuild (upload_log);
+CREATE INDEX livefsbuild__build_farm_job__idx
+    ON LiveFSBuild (build_farm_job);
+
+CREATE TABLE LiveFSFile (
+    id serial PRIMARY KEY,
+    livefsbuild integer NOT NULL REFERENCES livefsbuild,
+    libraryfile integer NOT NULL REFERENCES libraryfilealias
+);
+
+COMMENT ON TABLE LiveFSFile IS 'A link between a live filesystem build and a file in the librarian that it produces.';
+COMMENT ON COLUMN LiveFSFile.livefsbuild IS 'The live filesystem build producing this file.';
+COMMENT ON COLUMN LiveFSFile.libraryfile IS 'A file in the librarian.';
+
+INSERT INTO LaunchpadDatabaseRevision VALUES (2209, 56, 0);

=== modified file 'database/schema/security.cfg'
--- database/schema/security.cfg	2014-04-01 04:17:33 +0000
+++ database/schema/security.cfg	2014-04-25 11:16:45 +0000
@@ -224,6 +224,9 @@
 public.launchpadstatistic               = SELECT
 public.libraryfilealias                 = SELECT, INSERT, UPDATE, DELETE
 public.libraryfiledownloadcount         = SELECT, INSERT, UPDATE
+public.livefs                           = SELECT, INSERT, UPDATE, DELETE
+public.livefsbuild                      = SELECT, INSERT, UPDATE, DELETE
+public.livefsfile                       = SELECT, INSERT, UPDATE, DELETE
 public.logintoken                       = SELECT, INSERT, UPDATE, DELETE
 public.mailinglist                      = SELECT, INSERT, UPDATE, DELETE
 public.mailinglistsubscription          = SELECT, INSERT, UPDATE, DELETE
@@ -424,6 +427,8 @@
 public.languagepack                     = SELECT
 public.libraryfilealias                 = SELECT, UPDATE, DELETE
 public.libraryfilecontent               = SELECT, UPDATE, DELETE
+public.livefsbuild                      = SELECT
+public.livefsfile                       = SELECT
 public.mergedirectivejob                = SELECT
 public.message                          = SELECT
 public.messageapproval                  = SELECT
@@ -955,6 +960,9 @@
 public.gpgkey                                 = SELECT
 public.libraryfilealias                       = SELECT, INSERT
 public.libraryfilecontent                     = SELECT, INSERT
+public.livefs                                 = SELECT
+public.livefsbuild                            = SELECT, UPDATE
+public.livefsfile                             = SELECT
 public.packageset                             = SELECT
 public.packagesetgroup                        = SELECT
 public.packagesetinclusion                    = SELECT
@@ -1354,6 +1362,9 @@
 public.language                         = SELECT
 public.libraryfilealias                 = SELECT, INSERT
 public.libraryfilecontent               = SELECT, INSERT
+public.livefs                           = SELECT, UPDATE
+public.livefsbuild                      = SELECT, UPDATE
+public.livefsfile                       = SELECT, INSERT, UPDATE
 public.message                          = SELECT, INSERT
 public.messagechunk                     = SELECT, INSERT
 public.milestone                        = SELECT
@@ -1458,6 +1469,8 @@
 public.language                         = SELECT
 public.libraryfilealias                 = SELECT, INSERT, UPDATE
 public.libraryfilecontent               = SELECT, INSERT
+public.livefsbuild                      = SELECT
+public.livefsfile                       = SELECT, UPDATE
 public.message                          = SELECT, INSERT
 public.messagechunk                     = SELECT, INSERT
 public.milestone                        = SELECT
@@ -2138,6 +2151,8 @@
 public.karmacategory                    = SELECT, DELETE
 public.karmatotalcache                  = SELECT, UPDATE, DELETE
 public.latestpersonsourcepackagereleasecache = SELECT, DELETE
+public.livefs                           = SELECT, UPDATE
+public.livefsbuild                      = SELECT, UPDATE
 public.logintoken                       = SELECT, UPDATE, DELETE
 public.mailinglist                      = SELECT, UPDATE
 public.mailinglistsubscription          = SELECT, DELETE


Follow ups