racket/collects/tests/mzscheme/date.ss
2005-05-27 18:56:37 +00:00

42 lines
1.1 KiB
Scheme

(load-relative "loadtest.ss")
(SECTION 'date)
(require (lib "date.ss"))
(define (test-find s m h d mo y)
(let* ([secs (find-seconds s m h d mo y)]
[date (seconds->date secs)])
(test #t 'same
(and (= s (date-second date))
(= m (date-minute date))
(= h (date-hour date))
(= d (date-day date))
(= mo (date-month date))
(= y (date-year date))))))
(test-find 0 0 0 1 4 1975)
(test-find 0 0 0 1 4 2005)
; Bad dates
(err/rt-test (find-seconds 0 0 0 0 0 1990) exn:fail?)
(err/rt-test (find-seconds 0 0 0 0 1 1990) exn:fail?)
(err/rt-test (find-seconds 0 0 0 1 0 1990) exn:fail?)
; Early/late
(err/rt-test (find-seconds 0 0 0 1 1 1490) exn:fail?)
(err/rt-test (find-seconds 0 0 0 1 1 2890) exn:fail?)
; 1990 April 1 was start of daylight savings:
(test-find 0 0 1 1 4 1990) ; ok
(let ([s (find-seconds 1 0 3 1 4 1990)]) ; ok
(when (date-dst? (seconds->date s))
; We have daylight savings here; 2:01 AM doesn't exist
(err/rt-test (find-seconds 0 1 2 1 4 1990) exn:fail?)
; This date is ambiguous; find-seconds should find
; one of the two possible values, though:
(test-find 0 30 1 27 10 1996)))
(report-errs)