RegressionTests__TimeDurationTest.st
author Claus Gittinger <cg@exept.de>
Thu, 10 May 2018 14:25:34 +0200
changeset 1922 a6d99b7a3447
parent 1921 5d52a8565d1d
child 1923 00f3085c5b71
permissions -rw-r--r--
#QUALITY by cg class: RegressionTests::TimeDurationTest added: #test_01_Addition #test_02_Subtraction #test_03_Multiplication #test_04_Division #test_05_Division removed: #test_01_Arithmetic #test_02_Arithmetic comment/format in: #test_03_Arithmetic

"{ Encoding: utf8 }"

"{ Package: 'stx:goodies/regression' }"

"{ NameSpace: RegressionTests }"

TestCase subclass:#TimeDurationTest
	instanceVariableNames:''
	classVariableNames:''
	poolDictionaries:''
	category:'tests-Regression-DateAndTime'
!


!TimeDurationTest methodsFor:'Testing'!

test_00_Basic
    |t|

    t := TimeDuration fromSeconds:1.
    self assert:(t asSeconds = 1).
    self assert:(t asMilliseconds == 1000).
    self assert:(t asMicroseconds = 1000000).
    self assert:(t asNanoseconds = 1000000000).
    self assert:(t asPicoseconds = 1000000000000).

    t := TimeDuration fromSeconds:1.5.
    self assert:(t asSeconds = 1).
    self assert:(t asTruncatedSeconds == 1).
    self assert:(t asExactSeconds = 1.5).
    self assert:(t asMilliseconds == 1500).
    self assert:(t asMicroseconds = 1500000).
    self assert:(t asNanoseconds = 1500000000).
    self assert:(t asPicoseconds = 1500000000000).

    t := TimeDuration fromMilliseconds:345.
    self assert:(t asSeconds = 0).
    self assert:(t asExactSeconds = 0.345).
    self assert:(t asTruncatedSeconds = 0).
    self assert:(t asMilliseconds == 345).
    self assert:(t asMicroseconds = 345000).
    self assert:(t asNanoseconds = 345000000).
    self assert:(t asPicoseconds = 345000000000).

    t := TimeDuration fromMicroseconds:345.
    self assert:(t asExactSeconds = 0.000345).
    self assert:(t asTruncatedSeconds = 0).
    self assert:(t asExactMilliseconds = 0.345).
    self assert:(t asTruncatedMilliseconds == 0).
    self assert:(t asMicroseconds = 345).
    self assert:(t asNanoseconds = 345000).
    self assert:(t asPicoseconds = 345000000).

    t := TimeDuration fromNanoseconds:345.
    self assert:(t asExactSeconds = 0.000000345).
    self assert:(t asTruncatedSeconds = 0).
    self assert:(t asTruncatedMilliseconds == 0).
    self assert:(t asExactMilliseconds = 0.000345).
    self assert:(t asTruncatedMicroseconds = 0).
    self assert:(t asExactMicroseconds = 0.345).
    self assert:(t asNanoseconds = 345).
    self assert:(t asPicoseconds = 345000).

    t := TimeDuration fromPicoseconds:345.
    self assert:(t asExactSeconds = 0.000000000345).
    self assert:(t asTruncatedSeconds = 0).
    self assert:(t asExactMilliseconds = 0.000000345).
    self assert:(t asTruncatedMilliseconds == 0).
    self assert:(t asExactMicroseconds = 0.000345).
    self assert:(t asTruncatedMicroseconds = 0).
    self assert:(t asExactNanoseconds = 0.345).
    self assert:(t asTruncatedNanoseconds = 0).
    self assert:(t asPicoseconds = 345).

    "
     self new test_00_Basic
    "
!

test_01_Addition
    |t1 t2 sum|

    t1 := TimeDuration fromSeconds:1.
    t2 := TimeDuration fromMilliseconds:1.
    sum := t1 + t2.

    self assert:(sum asMilliseconds == 1001).
    self assert:(sum asMicroseconds = 1001000).
    self assert:(sum asNanoseconds = 1001000000).
    self assert:(sum asPicoseconds = 1001000000000).


    t1 := TimeDuration fromSeconds:1.
    t2 := TimeDuration fromMicroseconds:1.
    sum := t1 + t2.

    self assert:(sum asMilliseconds == 1000).
    self assert:(sum asMicroseconds = 1000001).
    self assert:(sum asNanoseconds = 1000001000).
    self assert:(sum asPicoseconds = 1000001000000).

    t1 := TimeDuration fromNanoseconds:100.
    t2 := TimeDuration fromNanoseconds:15.5.
    sum := t1 + t2.

    self assert:(sum asNanoseconds = 115).
    self assert:(sum asPicoseconds = 115500).


    "
     self new test_01_Addition
    "
!

test_02_Subtraction
    |t1 t2 sum|

    t1 := TimeDuration fromSeconds:1.
    t2 := TimeDuration fromMilliseconds:1.
    sum := t1 - t2.

    self assert:(sum asMilliseconds == 999).
    self assert:(sum asMicroseconds = 999000).
    self assert:(sum asNanoseconds = 999000000).
    self assert:(sum asPicoseconds = 999000000000).


    t1 := TimeDuration fromSeconds:1.
    t2 := TimeDuration fromMicroseconds:1.
    sum := t1 - t2.

    self assert:(sum asMilliseconds == 999).
    self assert:(sum asMicroseconds = 999999).
    self assert:(sum asNanoseconds = 999999000).
    self assert:(sum asPicoseconds = 999999000000).

    t1 := TimeDuration fromNanoseconds:100.
    t2 := TimeDuration fromNanoseconds:15.5.
    sum := t1 - t2.

    self assert:(sum asNanoseconds = 84).
    self assert:(sum asPicoseconds = 84500).


    "
     self new test_01_Subtraction
    "
!

test_03_Multiplication
    |t rslt|

    t := TimeDuration fromSeconds:1.
    rslt := t * 5.
    self assert:(rslt asMilliseconds == 5000).
    self assert:(rslt asPicoseconds = 5000000000000).

    rslt := 5 * t.
    self assert:(rslt asMilliseconds == 5000).
    self assert:(rslt asPicoseconds = 5000000000000).


    t := TimeDuration fromSeconds:1.1.
    rslt := t * 2.
    self assert:(rslt asMilliseconds == 2200).
    self assert:(rslt asPicoseconds = 2200000000000).

    rslt := 2 * t.
    self assert:(rslt asMilliseconds == 2200).
    self assert:(rslt asPicoseconds = 2200000000000).


    t := TimeDuration fromNanoseconds:100.
    rslt := t * 4.5.
    self assert:(rslt asNanoseconds = 450).
    self assert:(rslt asPicoseconds = 450000).

    rslt := 4.5 * t.
    self assert:(rslt asNanoseconds = 450).
    self assert:(rslt asPicoseconds = 450000).


    t := TimeDuration fromMilliseconds:100.
    t := t + 50 nanoseconds.

    rslt := t * 5.
    self assert:(rslt asNanoseconds = 500000250).

    rslt := 5 * t.
    self assert:(rslt asNanoseconds = 500000250).


    "
     self new test_03_Multiplication
    "
!

test_04_Division
    |t rslt|

    t := TimeDuration fromSeconds:1.
    rslt := t / 5.
    self assert:(rslt asMilliseconds == 200).
    self assert:(rslt asPicoseconds = 200000000000).


    t := TimeDuration fromSeconds:2.2.
    rslt := t / 2.
    self assert:(rslt asMilliseconds == 1100).
    self assert:(rslt asPicoseconds = 1100000000000).


    t := TimeDuration fromNanoseconds:450.
    rslt := t / 4.5.
    self assert:(rslt asNanoseconds = 100).
    self assert:(rslt asPicoseconds = 100000).


    t := TimeDuration fromMilliseconds:100.
    t := t + 50 nanoseconds.

    rslt := t / 5.
    self assert:(rslt asNanoseconds = 20000010).


    "
     self new test_04_Division
    "
!

test_05_Division    
    "dividing two timeDurations gives a numeric quotient"

    |t1 t2 rslt|

    t1 := TimeDuration fromSeconds:1.
    t2 := TimeDuration fromSeconds:2.
    rslt := t1 / t2.
    self assert:(rslt isNumber).
    self assert:(rslt = 0.5).

    t1 := TimeDuration fromSeconds:1.
    t2 := TimeDuration fromMilliseconds:1.
    rslt := t1 / t2.
    self assert:(rslt isNumber).
    self assert:(rslt = 1000).

    t1 := TimeDuration fromMilliseconds:1.
    t2 := TimeDuration fromMicroseconds:1.
    rslt := t1 / t2.
    self assert:(rslt isNumber).
    self assert:(rslt = 1000).

    t1 := TimeDuration fromMicroseconds:1.
    t2 := TimeDuration fromNanoseconds:1.
    rslt := t1 / t2.
    self assert:(rslt isNumber).
    self assert:(rslt = 1000).

    t1 := TimeDuration fromSeconds:1.
    t2 := TimeDuration fromNanoseconds:1.
    rslt := t1 / t2.
    self assert:(rslt isNumber).
    self assert:(rslt = 1000000000).

    t1 := TimeDuration fromSeconds:1.
    t2 := TimeDuration fromNanoseconds:50.
    rslt := t1 / t2.
    self assert:(rslt isNumber).
    self assert:(rslt = 20000000).


    "
     self new test_05_Division
    "
!

test_05_Reading
    |t1 t2|

    t2 := TimeDuration fromString:'1.001s'.
    self assert:(t2 asMilliseconds == 1001).

    t1 := TimeDuration fromString:'1001ms'.
    self assert:(t1 asMilliseconds = 1001).

    t1 := TimeDuration fromString:'1001ns'.
    self assert:(t1 asNanoseconds = 1001).

    t1 := TimeDuration fromString:'1001us'.
    self assert:(t1 asMicroseconds = 1001).

    t1 := TimeDuration fromString:'1001ps'.
    self assert:(t1 asPicoseconds = 1001).

    t1 := TimeDuration fromString:'1s 30us'.
    self assert:(t1 asMicroseconds = 1000030).

    t1 := TimeDuration fromString:'0.1s'.
    self assert:(t1 asMilliseconds = 100).
    t1 := TimeDuration fromString:'0.1ms'.
    self assert:(t1 asMicroseconds = 100).
    t1 := TimeDuration fromString:'0.1us'.
    self assert:(t1 asNanoseconds = 100).
    t1 := TimeDuration fromString:'0.1ns'.
    self assert:(t1 asPicoseconds = 100).

    t1 := TimeDuration fromString:'0,1ns'.
    self assert:(t1 asPicoseconds = 100).

    t1 := TimeDuration fromString:'01:30:33'.
    self assert:(t1 asSeconds = ((1*3600)+(30*60)+33)).
    self assert:(t1 asMilliseconds = (((1*3600)+(30*60)+33)*1000)).

    t1 := TimeDuration fromString:'01:30:33.5'.
    self assert:(t1 asSeconds = ((1*3600)+(30*60)+33)).
    self assert:(t1 asMilliseconds = ((((1*3600)+(30*60)+33)*1000)+500)).

    t1 := TimeDuration fromString:'01:30:33,5'.
    self assert:(t1 asSeconds = ((1*3600)+(30*60)+33)).
    self assert:(t1 asMilliseconds = ((((1*3600)+(30*60)+33)*1000)+500)).

    t1 := TimeDuration fromString:'01:30:33,05'.
    self assert:(t1 asSeconds = ((1*3600)+(30*60)+33)).
    self assert:(t1 asMilliseconds = ((((1*3600)+(30*60)+33)*1000)+50)).

    t1 := TimeDuration fromString:'01:30:33,005'.
    self assert:(t1 asSeconds = ((1*3600)+(30*60)+33)).
    self assert:(t1 asMilliseconds = ((((1*3600)+(30*60)+33)*1000)+5)).

    t1 := TimeDuration fromString:'01:30:33,0005'.
    self assert:(t1 asSeconds = ((1*3600)+(30*60)+33)).
    self assert:(t1 asMicroseconds = ((((1*3600)+(30*60)+33)*1000*1000)+500)).

    t1 := TimeDuration fromString:'01:30:33,00005'.
    self assert:(t1 asSeconds = ((1*3600)+(30*60)+33)).
    self assert:(t1 asMicroseconds = ((((1*3600)+(30*60)+33)*1000*1000)+50)).

    t1 := TimeDuration fromString:'01:30:33,000005'.
    self assert:(t1 asSeconds = ((1*3600)+(30*60)+33)).
    self assert:(t1 asMicroseconds = ((((1*3600)+(30*60)+33)*1000*1000)+5)).

    t1 := TimeDuration fromString:'01:30:33,0000005'.
    self assert:(t1 asSeconds = ((1*3600)+(30*60)+33)).
    self assert:(t1 asNanoseconds = ((((1*3600)+(30*60)+33)*1000*1000*1000)+500)).

    t1 := TimeDuration fromString:'01:30:33,00000005'.
    self assert:(t1 asSeconds = ((1*3600)+(30*60)+33)).
    self assert:(t1 asNanoseconds = ((((1*3600)+(30*60)+33)*1000*1000*1000)+50)).

    t1 := TimeDuration fromString:'01:30:33,000000005'.
    self assert:(t1 asSeconds = ((1*3600)+(30*60)+33)).
    self assert:(t1 asNanoseconds = ((((1*3600)+(30*60)+33)*1000*1000*1000)+5)).

    t1 := TimeDuration fromString:'0.000000005'.
    self assert:(t1 asNanoseconds = 5).

    t1 := TimeDuration fromString:'0.000000005s'.
    self assert:(t1 asNanoseconds = 5).

    t1 := TimeDuration fromString:'1d 5h'.
    self assert:(t1 asTruncatedHours = 29).

    t1 := TimeDuration fromString:'1d 5h 30m'.
    self assert:(t1 asTruncatedHours = 29).
    self assert:(t1 asExactHours = 29.5).

    "
     self new test_05_Reading
    "
!

test_10_PrintingReading
     #(
        "/ hours minutes seconds millis
        (0 0 0 0)
        (0 0 0 1)
        (0 0 0 9)
        (0 0 0 10)
        (0 0 0 11)
        (0 0 0 99)
        (0 0 0 100)
        (0 0 0 101)
        (0 0 0 999)
        (0 0 0 1000)
        (0 0 0 1001)

        (0 33 0 123)
        (2 0 0 123)
        (2 33 0 123)
        (100 33 0 123)
        (10000 33 0 123)
        (1000000 33 0 123)

        (2 33 0 0)
        (2 0 0 0)
        (24 0 0 0)
        (0 0 0 123)
    ) do:[:hmsms |
        |h m s ms d1 d2 s1 s2|

        h := hmsms first.
        m := hmsms second.
        s := hmsms third.
        ms := hmsms fourth.
        "/ generate a duration
        d1 := TimeDuration hours:h minutes:m seconds:s milliseconds:ms.
        "/ print it
        s1 := d1 printString.
        "/ read it back
        d2 := TimeDuration readFrom:s1.
        s2 := d2 printString.
        "/ same time?
        self assert:(d1 = d2).
        self assert:(d1 timeEncoding = d2 timeEncoding).
        "/ same string?
        self assert:(s1 = s2).
     ].


"/     (TimeDuration hours:0 minutes:0 seconds:0 milliseconds:123) printStringFormat:'%h:%m:%s'
"/     (TimeDuration hours:0 minutes:0 seconds:10 milliseconds:123) printStringFormat:'%h:%m:%s'
"/     (TimeDuration hours:0 minutes:33 seconds:0 milliseconds:123) printStringFormat:'%h:%m:%s'
"/     (TimeDuration hours:2 minutes:33 seconds:0 milliseconds:123) printStringFormat:'%h:%m:%s'
"/     (TimeDuration hours:100 minutes:33 seconds:0 milliseconds:123) printStringFormat:'%h:%m:%s'
"/     (TimeDuration hours:10000 minutes:33 seconds:0 milliseconds:123) printStringFormat:'%h:%m:%s'
"/     (TimeDuration hours:1000000 minutes:33 seconds:0 milliseconds:123) printStringFormat:'%h:%m:%s'

    "
     self new test_10_PrintingReading
    "

    "Created: / 18-07-2007 / 14:02:01 / cg"
! !

!TimeDurationTest class methodsFor:'documentation'!

version
    ^ '$Header$'
!

version_CVS
    ^ '$Header$'
! !