6 use Test::SQL::Translator;
10 use SQL::Translator::Schema::Constants;
14 maybe_plan(1, 'SQL::Translator::Parser::XML::SQLFairy',
15 'SQL::Translator::Producer::DB2');
18 my $xmlfile = "$Bin/data/xml/schema.xml";
21 $sqlt = SQL::Translator->new(
27 die "Can't find test schema $xmlfile" unless -e $xmlfile;
29 my @sql = $sqlt->translate(
30 from => 'XML-SQLFairy',
33 ) or die $sqlt->error;
35 my $want = [ 'DROP TABLE Basic;',
36 q|CREATE TABLE Basic (
37 id INTEGER GENERATED BY DEFAULT AS IDENTITY (START WITH 1, INCREMENT BY 1) NOT NULL,
38 title VARCHAR(100) NOT NULL DEFAULT 'hello',
39 description VARCHAR(0) DEFAULT '',
41 explicitnulldef VARCHAR(0),
42 explicitemptystring VARCHAR(0) DEFAULT '',
43 emptytagdef VARCHAR(0) DEFAULT '',
44 another_id INTEGER DEFAULT 2,
47 CONSTRAINT emailuniqueindex UNIQUE (email)
50 'DROP TABLE Another;',
52 q|CREATE TABLE Another (
53 id INTEGER GENERATED BY DEFAULT AS IDENTITY (START WITH 1, INCREMENT BY 1) NOT NULL,
57 'ALTER TABLE Basic ADD FOREIGN KEY (another_id) REFERENCES Another(id);',
59 'CREATE INDEX titleindex ON Basic ( title );',
61 'CREATE VIEW email_list AS
62 SELECT email FROM Basic WHERE email IS NOT NULL;',
64 'CREATE TRIGGER foo_trigger after insert ON Basic REFERENCING OLD AS oldrow NEW AS newrow FOR EACH ROW MODE DB2SQL update modified=timestamp();',
66 'CREATE TRIGGER bar_trigger before insert, update ON Basic REFERENCING OLD AS oldrow NEW AS newrow FOR EACH ROW MODE DB2SQL update modified2=timestamp();',
69 is_deeply(\@sql, $want, 'Got correct DB2 statements in list context');