3 test_description='test date parsing and printing'
 
   6 # arbitrary reference time: 2009-08-30 19:20:00
 
   7 TEST_DATE_NOW=1251660000; export TEST_DATE_NOW
 
  10         t=$(($TEST_DATE_NOW - $1))
 
  11         echo "$t -> $2" >expect
 
  12         test_expect_${3:-success} "relative date ($2)" "
 
  13         test-tool date relative $t >actual &&
 
  14         test_i18ncmp expect actual
 
  18 check_relative 5 '5 seconds ago'
 
  19 check_relative 300 '5 minutes ago'
 
  20 check_relative 18000 '5 hours ago'
 
  21 check_relative 432000 '5 days ago'
 
  22 check_relative 1728000 '3 weeks ago'
 
  23 check_relative 13000000 '5 months ago'
 
  24 check_relative 37500000 '1 year, 2 months ago'
 
  25 check_relative 55188000 '1 year, 9 months ago'
 
  26 check_relative 630000000 '20 years ago'
 
  27 check_relative 31449600 '12 months ago'
 
  28 check_relative 62985600 '2 years ago'
 
  36         test_expect_success $prereqs "show date ($format:$time)" '
 
  37                 echo "$time -> $expect" >expect &&
 
  38                 TZ=${zone:-$TZ} test-tool date show:"$format" "$time" >actual &&
 
  39                 test_cmp expect actual
 
  43 # arbitrary but sensible time for examples
 
  44 TIME='1466000000 +0200'
 
  45 check_show iso8601 "$TIME" '2016-06-15 16:13:20 +0200'
 
  46 check_show iso8601-strict "$TIME" '2016-06-15T16:13:20+02:00'
 
  47 check_show rfc2822 "$TIME" 'Wed, 15 Jun 2016 16:13:20 +0200'
 
  48 check_show short "$TIME" '2016-06-15'
 
  49 check_show default "$TIME" 'Wed Jun 15 16:13:20 2016 +0200'
 
  50 check_show raw "$TIME" '1466000000 +0200'
 
  51 check_show unix "$TIME" '1466000000'
 
  52 check_show iso-local "$TIME" '2016-06-15 14:13:20 +0000'
 
  53 check_show raw-local "$TIME" '1466000000 +0000'
 
  54 check_show unix-local "$TIME" '1466000000'
 
  56 check_show 'format:%z' "$TIME" '+0200'
 
  57 check_show 'format-local:%z' "$TIME" '+0000'
 
  58 check_show 'format:%Z' "$TIME" ''
 
  59 check_show 'format-local:%Z' "$TIME" 'UTC'
 
  60 check_show 'format:%%z' "$TIME" '%z'
 
  61 check_show 'format-local:%%z' "$TIME" '%z'
 
  63 check_show 'format:%Y-%m-%d %H:%M:%S' "$TIME" '2016-06-15 16:13:20'
 
  64 check_show 'format-local:%Y-%m-%d %H:%M:%S' "$TIME" '2016-06-15 09:13:20' '' EST5
 
  66 # arbitrary time absurdly far in the future
 
  67 FUTURE="5758122296 -0400"
 
  68 check_show iso       "$FUTURE" "2152-06-19 18:24:56 -0400" TIME_IS_64BIT,TIME_T_IS_64BIT
 
  69 check_show iso-local "$FUTURE" "2152-06-19 22:24:56 +0000" TIME_IS_64BIT,TIME_T_IS_64BIT
 
  72         echo "$1 -> $2" >expect
 
  73         test_expect_${4:-success} "parse date ($1${3:+ TZ=$3})" "
 
  74         TZ=${3:-$TZ} test-tool date parse '$1' >actual &&
 
  75         test_cmp expect actual
 
  80 check_parse 2008-02 bad
 
  81 check_parse 2008-02-14 bad
 
  82 check_parse '2008-02-14 20:30:45' '2008-02-14 20:30:45 +0000'
 
  83 check_parse '2008-02-14 20:30:45 -0500' '2008-02-14 20:30:45 -0500'
 
  84 check_parse '2008-02-14 20:30:45 -0015' '2008-02-14 20:30:45 -0015'
 
  85 check_parse '2008-02-14 20:30:45 -5' '2008-02-14 20:30:45 +0000'
 
  86 check_parse '2008-02-14 20:30:45 -5:' '2008-02-14 20:30:45 +0000'
 
  87 check_parse '2008-02-14 20:30:45 -05' '2008-02-14 20:30:45 -0500'
 
  88 check_parse '2008-02-14 20:30:45 -:30' '2008-02-14 20:30:45 +0000'
 
  89 check_parse '2008-02-14 20:30:45 -05:00' '2008-02-14 20:30:45 -0500'
 
  90 check_parse '2008-02-14 20:30:45' '2008-02-14 20:30:45 -0500' EST5
 
  93         echo "$1 -> $2 +0000" >expect
 
  94         test_expect_${3:-success} "parse approxidate ($1)" "
 
  95         test-tool date approxidate '$1' >actual &&
 
  96         test_cmp expect actual
 
 100 check_approxidate now '2009-08-30 19:20:00'
 
 101 check_approxidate '5 seconds ago' '2009-08-30 19:19:55'
 
 102 check_approxidate 5.seconds.ago '2009-08-30 19:19:55'
 
 103 check_approxidate 10.minutes.ago '2009-08-30 19:10:00'
 
 104 check_approxidate yesterday '2009-08-29 19:20:00'
 
 105 check_approxidate 3.days.ago '2009-08-27 19:20:00'
 
 106 check_approxidate 3.weeks.ago '2009-08-09 19:20:00'
 
 107 check_approxidate 3.months.ago '2009-05-30 19:20:00'
 
 108 check_approxidate 2.years.3.months.ago '2007-05-30 19:20:00'
 
 110 check_approxidate '6am yesterday' '2009-08-29 06:00:00'
 
 111 check_approxidate '6pm yesterday' '2009-08-29 18:00:00'
 
 112 check_approxidate '3:00' '2009-08-30 03:00:00'
 
 113 check_approxidate '15:00' '2009-08-30 15:00:00'
 
 114 check_approxidate 'noon today' '2009-08-30 12:00:00'
 
 115 check_approxidate 'noon yesterday' '2009-08-29 12:00:00'
 
 117 check_approxidate 'last tuesday' '2009-08-25 19:20:00'
 
 118 check_approxidate 'July 5th' '2009-07-05 19:20:00'
 
 119 check_approxidate '06/05/2009' '2009-06-05 19:20:00'
 
 120 check_approxidate '06.05.2009' '2009-05-06 19:20:00'
 
 122 check_approxidate 'Jun 6, 5AM' '2009-06-06 05:00:00'
 
 123 check_approxidate '5AM Jun 6' '2009-06-06 05:00:00'
 
 124 check_approxidate '6AM, June 7, 2009' '2009-06-07 06:00:00'
 
 126 check_approxidate '2008-12-01' '2008-12-01 19:20:00'
 
 127 check_approxidate '2009-12-01' '2009-12-01 19:20:00'