1#!/bin/sh
   2test_description='test date parsing and printing'
   4. ./test-lib.sh
   5# arbitrary reference time: 2009-08-30 19:20:00
   7GIT_TEST_DATE_NOW=1251660000; export GIT_TEST_DATE_NOW
   8check_relative() {
  10        t=$(($GIT_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
  15        "
  16}
  17check_relative 5 '5 seconds ago'
  19check_relative 300 '5 minutes ago'
  20check_relative 18000 '5 hours ago'
  21check_relative 432000 '5 days ago'
  22check_relative 1728000 '3 weeks ago'
  23check_relative 13000000 '5 months ago'
  24check_relative 37500000 '1 year, 2 months ago'
  25check_relative 55188000 '1 year, 9 months ago'
  26check_relative 630000000 '20 years ago'
  27check_relative 31449600 '12 months ago'
  28check_relative 62985600 '2 years ago'
  29check_show () {
  31        format=$1
  32        time=$2
  33        expect=$3
  34        prereqs=$4
  35        zone=$5
  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
  40        '
  41}
  42# arbitrary but sensible time for examples
  44TIME='1466000000 +0200'
  45check_show iso8601 "$TIME" '2016-06-15 16:13:20 +0200'
  46check_show iso8601-strict "$TIME" '2016-06-15T16:13:20+02:00'
  47check_show rfc2822 "$TIME" 'Wed, 15 Jun 2016 16:13:20 +0200'
  48check_show short "$TIME" '2016-06-15'
  49check_show default "$TIME" 'Wed Jun 15 16:13:20 2016 +0200'
  50check_show raw "$TIME" '1466000000 +0200'
  51check_show unix "$TIME" '1466000000'
  52check_show iso-local "$TIME" '2016-06-15 14:13:20 +0000'
  53check_show raw-local "$TIME" '1466000000 +0000'
  54check_show unix-local "$TIME" '1466000000'
  55check_show 'format:%z' "$TIME" '+0200'
  57check_show 'format-local:%z' "$TIME" '+0000'
  58check_show 'format:%Z' "$TIME" ''
  59check_show 'format-local:%Z' "$TIME" 'UTC'
  60check_show 'format:%%z' "$TIME" '%z'
  61check_show 'format-local:%%z' "$TIME" '%z'
  62check_show 'format:%Y-%m-%d %H:%M:%S' "$TIME" '2016-06-15 16:13:20'
  64check_show 'format-local:%Y-%m-%d %H:%M:%S' "$TIME" '2016-06-15 09:13:20' '' EST5
  65# arbitrary time absurdly far in the future
  67FUTURE="5758122296 -0400"
  68check_show iso       "$FUTURE" "2152-06-19 18:24:56 -0400" TIME_IS_64BIT,TIME_T_IS_64BIT
  69check_show iso-local "$FUTURE" "2152-06-19 22:24:56 +0000" TIME_IS_64BIT,TIME_T_IS_64BIT
  70check_parse() {
  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
  76        "
  77}
  78check_parse 2008 bad
  80check_parse 2008-02 bad
  81check_parse 2008-02-14 bad
  82check_parse '2008-02-14 20:30:45' '2008-02-14 20:30:45 +0000'
  83check_parse '2008-02-14 20:30:45 -0500' '2008-02-14 20:30:45 -0500'
  84check_parse '2008-02-14 20:30:45 -0015' '2008-02-14 20:30:45 -0015'
  85check_parse '2008-02-14 20:30:45 -5' '2008-02-14 20:30:45 +0000'
  86check_parse '2008-02-14 20:30:45 -5:' '2008-02-14 20:30:45 +0000'
  87check_parse '2008-02-14 20:30:45 -05' '2008-02-14 20:30:45 -0500'
  88check_parse '2008-02-14 20:30:45 -:30' '2008-02-14 20:30:45 +0000'
  89check_parse '2008-02-14 20:30:45 -05:00' '2008-02-14 20:30:45 -0500'
  90check_parse '2008-02-14 20:30:45' '2008-02-14 20:30:45 -0500' EST5
  91check_approxidate() {
  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
  97        "
  98}
  99check_approxidate now '2009-08-30 19:20:00'
 101check_approxidate '5 seconds ago' '2009-08-30 19:19:55'
 102check_approxidate 5.seconds.ago '2009-08-30 19:19:55'
 103check_approxidate 10.minutes.ago '2009-08-30 19:10:00'
 104check_approxidate yesterday '2009-08-29 19:20:00'
 105check_approxidate 3.days.ago '2009-08-27 19:20:00'
 106check_approxidate 3.weeks.ago '2009-08-09 19:20:00'
 107check_approxidate 3.months.ago '2009-05-30 19:20:00'
 108check_approxidate 2.years.3.months.ago '2007-05-30 19:20:00'
 109check_approxidate '6am yesterday' '2009-08-29 06:00:00'
 111check_approxidate '6pm yesterday' '2009-08-29 18:00:00'
 112check_approxidate '3:00' '2009-08-30 03:00:00'
 113check_approxidate '15:00' '2009-08-30 15:00:00'
 114check_approxidate 'noon today' '2009-08-30 12:00:00'
 115check_approxidate 'noon yesterday' '2009-08-29 12:00:00'
 116check_approxidate 'January 5th noon pm' '2009-01-05 12:00:00'
 117check_approxidate '10am noon' '2009-08-29 12:00:00'
 118check_approxidate 'last tuesday' '2009-08-25 19:20:00'
 120check_approxidate 'July 5th' '2009-07-05 19:20:00'
 121check_approxidate '06/05/2009' '2009-06-05 19:20:00'
 122check_approxidate '06.05.2009' '2009-05-06 19:20:00'
 123check_approxidate 'Jun 6, 5AM' '2009-06-06 05:00:00'
 125check_approxidate '5AM Jun 6' '2009-06-06 05:00:00'
 126check_approxidate '6AM, June 7, 2009' '2009-06-07 06:00:00'
 127check_approxidate '2008-12-01' '2008-12-01 19:20:00'
 129check_approxidate '2009-12-01' '2009-12-01 19:20:00'
 130check_date_format_human() {
 132        t=$(($GIT_TEST_DATE_NOW - $1))
 133        echo "$t -> $2" >expect
 134        test_expect_success "human date $t" '
 135                test-tool date human $t >actual &&
 136                test_i18ncmp expect actual
 137'
 138}
 139check_date_format_human 18000 "5 hours ago" # 5 hours ago
 141check_date_format_human 432000 "Tue Aug 25 19:20" # 5 days ago
 142check_date_format_human 1728000 "Mon Aug 10 19:20" # 3 weeks ago
 143check_date_format_human 13000000 "Thu Apr 2 08:13" # 5 months ago
 144check_date_format_human 31449600 "Aug 31 2008" # 12 months ago
 145check_date_format_human 37500000 "Jun 22 2008" # 1 year, 2 months ago
 146check_date_format_human 55188000 "Dec 1 2007" # 1 year, 9 months ago
 147check_date_format_human 630000000 "Sep 13 1989" # 20 years ago
 148test_done