diff options
| author | Yukihiro "Matz" Matsumoto <[email protected]> | 2012-06-04 16:53:20 -0700 |
|---|---|---|
| committer | Yukihiro "Matz" Matsumoto <[email protected]> | 2012-06-04 16:53:20 -0700 |
| commit | a7707baecd7760252377e275bb325ea441d52676 (patch) | |
| tree | 648085f97d2f79e1ae78362e23bc46cf0c03f021 | |
| parent | 0b4f33213729a87e146d990604330c70896dac07 (diff) | |
| parent | db6c374301421245ef4746f71891ec03509a4085 (diff) | |
| download | mruby-a7707baecd7760252377e275bb325ea441d52676.tar.gz mruby-a7707baecd7760252377e275bb325ea441d52676.zip | |
Merge pull request #243 from bovi/improve-time-and-test
Improve Time
| -rw-r--r-- | src/time.c | 1 | ||||
| -rw-r--r-- | test/t/time.rb | 126 |
2 files changed, 120 insertions, 7 deletions
diff --git a/src/time.c b/src/time.c index eea92e604..24d86bc33 100644 --- a/src/time.c +++ b/src/time.c @@ -694,6 +694,7 @@ mrb_init_time(mrb_state *mrb) mrb_define_class_method(mrb, tc, "local", mrb_time_local, ARGS_REQ(1)|ARGS_OPT(6)); /* 15.2.19.6.3 */ mrb_define_class_method(mrb, tc, "mktime", mrb_time_local, ARGS_REQ(1)|ARGS_OPT(6));/* 15.2.19.6.4 */ mrb_define_class_method(mrb, tc, "now", mrb_time_now, ARGS_NONE()); /* 15.2.19.6.5 */ + mrb_define_class_method(mrb, tc, "utc", mrb_time_gm, ARGS_REQ(1)|ARGS_OPT(6)); /* 15.2.19.6.6 */ mrb_define_method(mrb, tc, "==" , mrb_time_eq , ARGS_REQ(1)); mrb_define_method(mrb, tc, "<=>" , mrb_time_cmp , ARGS_REQ(1)); /* 15.2.19.7.1 */ diff --git a/test/t/time.rb b/test/t/time.rb index 7d1519f63..045c5b185 100644 --- a/test/t/time.rb +++ b/test/t/time.rb @@ -1,6 +1,10 @@ ## # Time ISO Test +assert('Time.new', '15.2.3.3.3') do + Time.new.class == Time +end + assert('Time', '15.2.19') do Time.class == Class end @@ -17,23 +21,133 @@ assert('Time.gm', '15.2.19.6.2') do Time.gm(2012, 12, 23) end +assert('Time.local', '15.2.19.6.3') do + Time.local(2012, 12, 23) +end + +assert('Time.mktime', '15.2.19.6.4') do + Time.mktime(2012, 12, 23) +end + +assert('Time.now', '15.2.19.6.5') do + Time.now.class == Time +end + +assert('Time.utc', '15.2.19.6.6') do + Time.utc(2012, 12, 23) +end + +assert('Time#+', '15.2.19.7.1') do + t1 = Time.at(1300000000.0) + t2 = t1.+(60) + + t2.utc.asctime == "Sun Mar 13 07:07:40 UTC 2011" +end + +assert('Time#-', '15.2.19.7.2') do + t1 = Time.at(1300000000.0) + t2 = t1.-(60) + + t2.utc.asctime == "Sun Mar 13 07:05:40 UTC 2011" +end + +assert('Time#<=>', '15.2.19.7.3') do + t1 = Time.at(1300000000.0) + t2 = Time.at(1400000000.0) + t3 = Time.at(1500000000.0) + + t2.<=>(t1) == 1 and + t2.<=>(t2) == 0 and + t2.<=>(t3) == -1 and + t2.<=>(nil) == nil +end + assert('Time#asctime', '15.2.19.7.4') do Time.at(1300000000.0).utc.asctime == "Sun Mar 13 07:06:40 UTC 2011" end +assert('Time#ctime', '15.2.19.7.5') do + Time.at(1300000000.0).utc.ctime == "Sun Mar 13 07:06:40 UTC 2011" +end + +assert('Time#day', '15.2.19.7.6') do + Time.gm(2012, 12, 23).day == 23 +end + +assert('Time#dst?', '15.2.19.7.7') do + not Time.gm(2012, 12, 23).utc.dst? +end + +assert('Time#getgm', '15.2.19.7.8') do + Time.at(1300000000.0).getgm.asctime == "Sun Mar 13 07:06:40 UTC 2011" +end + +assert('Time#getlocal', '15.2.19.7.9') do + t1 = Time.at(1300000000.0) + t2 = Time.at(1300000000.0) + t3 = t1.getlocal + + t1 == t3 and t3 == t2.getlocal +end + +assert('Time#getutc', '15.2.19.7.10') do + Time.at(1300000000.0).getutc.asctime == "Sun Mar 13 07:06:40 UTC 2011" +end + +assert('Time#gmt?', '15.2.19.7.11') do + Time.at(1300000000.0).utc.gmt? +end + +# ATM not implemented +# assert('Time#gmt_offset', '15.2.19.7.12') do + +assert('Time#gmtime', '15.2.19.7.13') do + Time.at(1300000000.0).gmtime +end + +# ATM not implemented +# assert('Time#gmtoff', '15.2.19.7.14') do + +assert('Time#hour', '15.2.19.7.15') do + Time.gm(2012, 12, 23, 7, 6).hour == 7 +end + +# ATM doesn't really work +# assert('Time#initialize', '15.2.19.7.16') do + assert('Time#initialize_copy', '15.2.19.7.17') do time_tmp_2 = Time.at(7.0e6) time_tmp_2.clone == time_tmp_2 end +assert('Time#localtime', '15.2.19.7.18') do + t1 = Time.at(1300000000.0) + t2 = Time.at(1300000000.0) + + t1.localtime + t1 == t2.getlocal +end + assert('Time#mday', '15.2.19.7.19') do Time.gm(2012, 12, 23).mday == 23 end +assert('Time#min', '15.2.19.7.20') do + Time.gm(2012, 12, 23, 7, 6).min == 6 +end + +assert('Time#mon', '15.2.19.7.21') do + Time.gm(2012, 12, 23).mon == 12 +end + assert('Time#month', '15.2.19.7.22') do Time.gm(2012, 12, 23).month == 12 end +assert('Times#sec', '15.2.19.7.23') do + Time.gm(2012, 12, 23, 7, 6, 40).sec == 40 +end + assert('Time#to_f', '15.2.19.7.24') do Time.at(1300000000.0).to_f == 1300000000.0 end @@ -54,12 +168,15 @@ assert('Time#utc?', '15.2.19.7.28') do Time.at(1300000000.0).utc.utc? end +# ATM not implemented +# assert('Time#utc_offset', '15.2.19.7.29') do + assert('Time#wday', '15.2.19.7.30') do - Time.at(1300000000.0).utc.wday == 0 + Time.gm(2012, 12, 23).wday == 0 end assert('Time#yday', '15.2.19.7.31') do - Time.at(1300000000.0).utc.yday == 71 + Time.gm(2012, 12, 23).yday == 357 end assert('Time#year', '15.2.19.7.32') do @@ -70,8 +187,3 @@ assert('Time#zone', '15.2.19.7.33') do Time.at(1300000000.0).utc.zone == 'UTC' end -# Not ISO specified - -assert('Time#new') do - Time.new.class == Time -end |
