Blob Blame History Raw
-- Copyright 2014 The Kyua Authors.
-- All rights reserved.
--
-- Redistribution and use in source and binary forms, with or without
-- modification, are permitted provided that the following conditions are
-- met:
--
-- * Redistributions of source code must retain the above copyright
--   notice, this list of conditions and the following disclaimer.
-- * Redistributions in binary form must reproduce the above copyright
--   notice, this list of conditions and the following disclaimer in the
--   documentation and/or other materials provided with the distribution.
-- * Neither the name of Google Inc. nor the names of its contributors
--   may be used to endorse or promote products derived from this software
--   without specific prior written permission.
--
-- THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-- "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-- LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-- A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-- OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-- SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-- LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-- DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-- THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-- (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-- OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.

-- \file store/v2-to-v3.sql
-- Migration of a database with version 2 of the schema to version 3.
--
-- Version 3 appeared in revision 084d740b1da635946d153475156e335ddfc4aed6
-- and its changes were:
--
-- * Removal of historical data.
--
-- Because from v2 to v3 we went from a unified database to many separate
-- databases, this file is parameterized on @ACTION_ID@.  The file has to
-- be executed once per action with this string replaced.


ATTACH DATABASE "@OLD_DATABASE@" AS old_store;


-- New database already contains a record for v3.  Just import older entries.
INSERT INTO metadata SELECT * FROM old_store.metadata;

INSERT INTO contexts
    SELECT cwd
    FROM old_store.actions
        NATURAL JOIN old_store.contexts
    WHERE action_id == @ACTION_ID@;

INSERT INTO env_vars
    SELECT var_name, var_value
    FROM old_store.actions
        NATURAL JOIN old_store.contexts
        NATURAL JOIN old_store.env_vars
    WHERE action_id == @ACTION_ID@;

INSERT INTO metadatas
    SELECT metadata_id, property_name, property_value
    FROM old_store.metadatas
    WHERE metadata_id IN (
        SELECT test_programs.metadata_id
            FROM old_store.test_programs
            WHERE action_id == @ACTION_ID@
    ) OR metadata_id IN (
        SELECT test_cases.metadata_id
            FROM old_store.test_programs JOIN old_store.test_cases
                ON test_programs.test_program_id == test_cases.test_program_id
            WHERE action_id == @ACTION_ID@
    );

INSERT INTO test_programs
    SELECT test_program_id, absolute_path, root, relative_path,
        test_suite_name, metadata_id, interface
    FROM old_store.test_programs
    WHERE action_id == @ACTION_ID@;

INSERT INTO test_cases
    SELECT test_cases.test_case_id, test_cases.test_program_id,
        test_cases.name, test_cases.metadata_id
    FROM old_store.test_cases JOIN old_store.test_programs
        ON test_cases.test_program_id == test_programs.test_program_id
    WHERE action_id == @ACTION_ID@;

INSERT INTO test_results
    SELECT test_results.test_case_id, test_results.result_type,
    test_results.result_reason, test_results.start_time, test_results.end_time
    FROM old_store.test_results
        JOIN old_store.test_cases
            ON test_results.test_case_id == test_cases.test_case_id
        JOIN old_store.test_programs
            ON test_cases.test_program_id == test_programs.test_program_id
    WHERE action_id == @ACTION_ID@;

INSERT INTO files
    SELECT files.file_id, files.contents
    FROM old_store.files
        JOIN old_store.test_case_files
            ON files.file_id == test_case_files.file_id
        JOIN old_store.test_cases
            ON test_case_files.test_case_id == test_cases.test_case_id
        JOIN old_store.test_programs
            ON test_cases.test_program_id == test_programs.test_program_id
    WHERE action_id == @ACTION_ID@;

INSERT INTO test_case_files
    SELECT test_case_files.test_case_id, test_case_files.file_name,
        test_case_files.file_id
    FROM old_store.test_case_files
        JOIN old_store.test_cases
            ON test_case_files.test_case_id == test_cases.test_case_id
        JOIN old_store.test_programs
            ON test_cases.test_program_id == test_programs.test_program_id
    WHERE action_id == @ACTION_ID@;


DETACH DATABASE old_store;