diff options
| author | Guilhem Moulin <guilhem@fripost.org> | 2019-05-27 00:40:24 +0200 | 
|---|---|---|
| committer | Guilhem Moulin <guilhem@fripost.org> | 2019-05-27 00:40:24 +0200 | 
| commit | e86590ad6858d0d597278393b8de2923dfed4084 (patch) | |
| tree | fae8916cc9a81107460df6af0baa26af6d2e0727 /tests/00-db-migration-0-to-1-foreign-key-violation/run | |
| parent | 6b9e183ea2abbe5137c7551eb8c5184eea51571e (diff) | |
| parent | 8e379c62a48d68cd5ab2a32c6fc9244b1ae94084 (diff) | |
Merge branch 'master' into HEAD
Diffstat (limited to 'tests/00-db-migration-0-to-1-foreign-key-violation/run')
| -rw-r--r-- | tests/00-db-migration-0-to-1-foreign-key-violation/run | 23 | 
1 files changed, 23 insertions, 0 deletions
| diff --git a/tests/00-db-migration-0-to-1-foreign-key-violation/run b/tests/00-db-migration-0-to-1-foreign-key-violation/run new file mode 100644 index 0000000..f2d12a9 --- /dev/null +++ b/tests/00-db-migration-0-to-1-foreign-key-violation/run @@ -0,0 +1,23 @@ +# create new schema and add INBOX +interimap +xgrep "^Creating new schema in database file " <"$STDERR" +xgrep -Fx "database: Created mailbox INBOX" <"$STDERR" + +# empty table `mailboxes` and revert its schema to version 0 +sqlite3 "$XDG_DATA_HOME/interimap/remote.db" <<-EOF +	PRAGMA foreign_keys = OFF; +	PRAGMA user_version = 0; +	DROP TABLE mailboxes; +	CREATE TABLE mailboxes ( +	    idx        INTEGER NOT NULL PRIMARY KEY AUTOINCREMENT, +	    mailbox    TEXT    NOT NULL CHECK (mailbox != '') UNIQUE, +	    subscribed BOOLEAN NOT NULL +	); +EOF + +# check that migration fails due to broken referential integrity +! interimap +xgrep -Fx "Upgrading database version from 0" <"$STDERR" +xgrep -Fx "database: ERROR: Broken referential integrity!  Refusing to commit changes." <"$STDERR" + +# vim: set filetype=sh : | 
