
The parser checks whether the FIRST or AFTER keywords are used and, if AFTER is used, extracts the relevant column name. Added a test case that checks that the parsing works and detects the correct column names.
100 lines
5.7 KiB
C
100 lines
5.7 KiB
C
#include "../avro_schema.c"
|
|
|
|
static struct
|
|
{
|
|
const char* statement;
|
|
const char* target;
|
|
bool rval;
|
|
} data[] =
|
|
{
|
|
{"/*!40000 ALTER TABLE `t1` DISABLE KEYS */", NULL, false},
|
|
{"/*!40000 ALTER TABLE `t1` ENABLE KEYS */", NULL, false},
|
|
{"ADD COLUMN `a` INT", NULL, false},
|
|
{"ADD COLUMN `a`", NULL, false},
|
|
{"ALTER TABLE `t1` ADD `account_id` INT", NULL, false},
|
|
{"ALTER TABLE `t1` ADD `amount` INT", NULL, false},
|
|
{"ALTER TABLE `t1` ADD `app_id` VARCHAR(64)", NULL, false},
|
|
{"ALTER TABLE `t1` ADD `create_time` DATETIME", NULL, false},
|
|
{"alter TABLE t1 add `end_time` varchar(10) DEFAULT NULL COMMENT 'this is a comment'", NULL, false},
|
|
{"ALTER TABLE `t1` ADD `expire_time` DATETIME", NULL, false},
|
|
{"ALTER TABLE `t1` ADD `id_a` VARCHAR(128)", NULL, false},
|
|
{"ALTER TABLE `t1` ADD `id` BIGINT(20)", NULL, false},
|
|
{"ALTER TABLE `t1` ADD `id` VARCHAR(64)", NULL, false},
|
|
{"ALTER TABLE `t1` ADD `node_state` INT(4)", NULL, false},
|
|
{"ALTER TABLE `t1` ADD `no` INT", NULL, false},
|
|
{"ALTER TABLE `t1` ADD `order_id` INT", NULL, false},
|
|
{"alter TABLE t1 add `start_time` varchar(10) DEFAULT NULL COMMENT 'this is a comment'", NULL, false},
|
|
{"ALTER TABLE `t1` ADD `status` INT", NULL, false},
|
|
{"ALTER TABLE `t1` ADD `task_id` BIGINT(20)", NULL, false},
|
|
{"alter TABLE t1 add `undo` int(1) DEFAULT '0' COMMENT 'this is a comment'", NULL, false},
|
|
{"alter table `t1` add unique (`a`,`id`)", NULL, false},
|
|
{"alter table `t1` add unique (`a`)", NULL, false},
|
|
{"alter table `t1` add UNIQUE(`a`)", NULL, false},
|
|
{"ALTER TABLE `t1` ADD UNIQUE `idx_id` USING BTREE (`id`, `result`)", NULL, false},
|
|
{"ALTER TABLE `t1` ADD `update_time` INT", NULL, false},
|
|
{"ALTER TABLE `t1` ADD `username` VARCHAR(16)", NULL, false},
|
|
{"ALTER TABLE `t1` AUTO_INCREMENT = 1", NULL, false},
|
|
{"ALTER TABLE `t1` CHANGE `account_id` `account_id` BIGINT(20)", NULL, false},
|
|
{"ALTER TABLE `t1` CHANGE `amount` `amount` DECIMAL(32,2)", NULL, false},
|
|
{"ALTER TABLE `t1` CHANGE `app_id` `app_id` VARCHAR(64)", NULL, false},
|
|
{"ALTER TABLE `t1` CHANGE `business_id` `business_id` VARCHAR(128)", NULL, false},
|
|
{"ALTER TABLE `t1` CHANGE `business_id` `business_id` VARCHAR(64)", NULL, false},
|
|
{"ALTER TABLE `t1` CHANGE `business_unique_no` `business_unique_no` VARCHAR(64)", NULL, false},
|
|
{"ALTER TABLE `t1` CHANGE `expire_time` `expire_time` DATETIME", NULL, false},
|
|
{"ALTER TABLE `t1` CHANGE `id_a` `id_a` VARCHAR(128)", NULL, false},
|
|
{"ALTER TABLE `t1` CHANGE `id` `id` BIGINT(20)", NULL, false},
|
|
{"ALTER TABLE `t1` CHANGE `node_state` `node_state` INT(4)", NULL, false},
|
|
{"ALTER TABLE `t1` CHANGE `order_id` `order_id` BIGINT(20)", NULL, false},
|
|
{"ALTER TABLE `t1` CHANGE `status` `status` INT(1)", NULL, false},
|
|
{"ALTER TABLE `t1` CHANGE `update_time` `update_time` TIMESTAMP", NULL, false},
|
|
{"ALTER TABLE `t1` CHANGE `username` `username` VARCHAR(16)", NULL, false},
|
|
{"ALTER TABLE `t1` COMMENT = 'a comment'", NULL, false},
|
|
{"alter table `t1` drop index a", NULL, false},
|
|
{"alter table t1 drop index t1_idx", NULL, false},
|
|
{"alter table t1 index(account_id, business_id)", NULL, false},
|
|
{"ALTER TABLE `t1` MODIFY COLUMN `expire_time` DATETIME DEFAULT NULL COMMENT 'this is a comment' AFTER `update_time`", "update_time", true},
|
|
{"ALTER TABLE `t1` MODIFY COLUMN `id_a` VARCHAR(128) CHARACTER SET utf8 COLLATE utf8_general_ci COMMENT 'this is a comment' AFTER `username`", "username", true},
|
|
{"ALTER TABLE `t1` MODIFY COLUMN `number` VARCHAR(64) CHARACTER SET utf8 COLLATE utf8_general_ci DEFAULT NULL COMMENT 'this is a comment' AFTER `business_id`", "business_id", true},
|
|
{"ALTER TABLE `t1` MODIFY COLUMN `task_id` BIGINT(20) DEFAULT NULL COMMENT 'this is a comment' AFTER `business_id`", "business_id", true},
|
|
{"ALTER TABLE `t1` MODIFY COLUMN `username` VARCHAR(16) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL COMMENT 'this is a comment' AFTER `business_id`", "business_id", true},
|
|
{"ALTER TABLE `t1` RENAME `t2`", NULL, false},
|
|
{"ALTER TABLE `db1`.`t1` ADD COLUMN `num` varchar(32) COMMENT 'this is a comment' AFTER `bank_name`", "bank_name", true},
|
|
{"ALTER TABLE `db1`.`t1` ADD INDEX `idx_node_state` USING BTREE (`node_state`) comment ''", NULL, false},
|
|
{"ALTER TABLE `db1`.`t1` CHANGE COLUMN `num` `code` varchar(32) DEFAULT NULL COMMENT 'this is a comment'", NULL, false},
|
|
{"ALTER TABLE `db1`.`t1` DROP INDEX `a`, ADD INDEX `a` USING BTREE (`a`) comment ''", NULL, false},
|
|
{"ALTER TABLE `db1`.`t1` DROP INDEX `a`, ADD INDEX `idx_a` USING BTREE (`a`) comment ''", NULL, false},
|
|
{"ALTER TABLE `t1` CHANGE COLUMN `a` `c` INT AFTER `b`", "b", true},
|
|
{"ALTER TABLE `t1` CHANGE COLUMN `a` `c` INT first", NULL, true},
|
|
{"ALTER TABLE `t1` CHANGE COLUMN `a` `c` INT", NULL, false},
|
|
{"ALTER TABLE `t1` MODIFY COLUMN `a` INT PRIMARY KEY", NULL, false},
|
|
{NULL}
|
|
};
|
|
|
|
int main(int argc, char** argv)
|
|
{
|
|
int rval = 0;
|
|
|
|
for (int i = 0; data[i].statement; i++)
|
|
{
|
|
const char* target = NULL;
|
|
int len = 0;
|
|
const char* stmt = data[i].statement;
|
|
const char* end = data[i].statement + strlen(data[i].statement);
|
|
|
|
if (get_placement_specifier(stmt, end, &target, &len) != data[i].rval)
|
|
{
|
|
const char* a = data[i].rval ? "true" : "false";
|
|
const char* b = data[i].rval ? "false" : "true";
|
|
printf("Expected '%s', got '%s' for '%s'\n", a, b, data[i].statement);
|
|
rval++;
|
|
}
|
|
else if (((bool)data[i].target != (bool)target) || (strncmp(target, data[i].target, len) != 0))
|
|
{
|
|
printf("Expected '%s', got '%.*s' for '%s'\n", data[i].target, len, target, data[i].statement);
|
|
rval++;
|
|
}
|
|
}
|
|
|
|
return rval;
|
|
}
|