use t::APISix 'no_plan';

repeat_each(1);
no_long_string();
no_root_location();
log_level("info");

run_tests;

__DATA__

=== TEST 1: sanity
--- config
    location /t {
        content_by_lua_block {
            local core = require("apisix.core")
            local function job()
                core.log.warn("job enter")
                ngx.sleep(0.5)
                core.log.warn("job exit")
            end

            local ok = core.timer.new("test job", job,
                {each_ttl = 2, check_interval = 0.1})
            ngx.say("create timer: ", type(ok))
            ngx.sleep(3)
        }
    }
--- request
GET /t
--- response_body
create timer: table
--- grep_error_log eval
qr/job (enter|exit)/
--- grep_error_log_out eval
qr/(job enter\njob exit)+/
--- timeout: 5