我对blackbox测试有一个相当大而复杂的mysql查询,这个查询是时间敏感的,它有很多基于current_timestamp
的条件。
我的目标是进行一些测试,以便它总是通过或失败。我想在运行查询之前暂时将current_timestamp
的值模拟到固定日期,并在查询后将其设置回原始值。
这是可行的吗?
我无法修改查询本身(即:将current current_timestamp替换为其他内容)
由于
答案 0 :(得分:2)
通过设置系统变量' timestamp'。要将其再次恢复为当前时间戳,请将其设置为DEFAULT。
mysql> SET TIMESTAMP = UNIX_TIMESTAMP('2015-01-01');
Query OK, 0 rows affected (0.00 sec)
mysql> SELECT NOW();
+---------------------+
| NOW() |
+---------------------+
| 2015-01-01 00:00:00 |
+---------------------+
1 row in set (0.00 sec)
mysql> SET TIMESTAMP = DEFAULT;
Query OK, 0 rows affected (0.00 sec)
mysql> SELECT NOW();
+---------------------+
| NOW() |
+---------------------+
| 2016-03-08 09:50:16 |
+---------------------+
1 row in set (0.00 sec)