RegressionTests__StreamTests.st
author Jan Vrany <jan.vrany@fit.cvut.cz>
Thu, 30 Jun 2016 09:02:08 +0100
branchjv
changeset 1500 d406a10b2965
parent 1499 26a16a04219b
parent 1447 2351db93aa5b
child 1507 cce35fc1d666
permissions -rw-r--r--
Merge
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1410
bb99d701dde7 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 1409
diff changeset
     1
"{ Encoding: utf8 }"
bb99d701dde7 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 1409
diff changeset
     2
1447
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
     3
"{ Package: 'stx:goodies/regression' }"
636
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     4
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     5
"{ NameSpace: RegressionTests }"
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     6
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     7
TestCase subclass:#StreamTests
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     8
	instanceVariableNames:''
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     9
	classVariableNames:''
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    10
	poolDictionaries:''
1085
29bb4657f206 category change
Claus Gittinger <cg@exept.de>
parents: 952
diff changeset
    11
	category:'tests-Regression-Streams'
636
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    12
!
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    13
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    14
!StreamTests class methodsFor:'documentation'!
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    15
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    16
documentation
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    17
"
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    18
    documentation to be added.
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    19
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    20
    [author:]
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    21
        cg
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    22
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    23
    [instance variables:]
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    24
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    25
    [class variables:]
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    26
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    27
    [see also:]
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    28
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    29
"
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    30
! !
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    31
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    32
!StreamTests class methodsFor:'queries'!
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    33
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    34
coveredClassNames
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    35
    ^ #(
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    36
        'PositionableStream'
1270
e47eb24afa27 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1251
diff changeset
    37
        'ReadStream'
e47eb24afa27 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1251
diff changeset
    38
        'WriteStream'
e47eb24afa27 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1251
diff changeset
    39
        'Stream'
636
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    40
    )
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    41
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    42
    "Created: / 16-09-2011 / 14:56:05 / cg"
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    43
! !
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    44
661
e1d4a83cc338 added: #setUp
Stefan Vogel <sv@exept.de>
parents: 637
diff changeset
    45
!StreamTests methodsFor:'setup'!
e1d4a83cc338 added: #setUp
Stefan Vogel <sv@exept.de>
parents: 637
diff changeset
    46
e1d4a83cc338 added: #setUp
Stefan Vogel <sv@exept.de>
parents: 637
diff changeset
    47
setUp
e1d4a83cc338 added: #setUp
Stefan Vogel <sv@exept.de>
parents: 637
diff changeset
    48
    (Smalltalk classNamed:'stx_libcompat') isNil ifTrue:[
e1d4a83cc338 added: #setUp
Stefan Vogel <sv@exept.de>
parents: 637
diff changeset
    49
        (Smalltalk loadPackage:'stx:libcompat') ifFalse:[
e1d4a83cc338 added: #setUp
Stefan Vogel <sv@exept.de>
parents: 637
diff changeset
    50
            self error:'libcompat cannot be loaded'.        
e1d4a83cc338 added: #setUp
Stefan Vogel <sv@exept.de>
parents: 637
diff changeset
    51
        ].
e1d4a83cc338 added: #setUp
Stefan Vogel <sv@exept.de>
parents: 637
diff changeset
    52
    ].
1278
35268b580937 class: RegressionTests::StreamTests
Stefan Vogel <sv@exept.de>
parents: 1270
diff changeset
    53
    (Smalltalk classNamed:'stx_libcompat') load.
661
e1d4a83cc338 added: #setUp
Stefan Vogel <sv@exept.de>
parents: 637
diff changeset
    54
! !
e1d4a83cc338 added: #setUp
Stefan Vogel <sv@exept.de>
parents: 637
diff changeset
    55
636
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    56
!StreamTests methodsFor:'tests'!
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    57
637
9dbf4cbf5bea added: #test01_numberReading_squeak
Claus Gittinger <cg@exept.de>
parents: 636
diff changeset
    58
test01_numberReading_squeak
636
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    59
    |b s val|
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    60
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    61
    b := #[1 2 3 4].
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    62
    s := b readStream.
661
e1d4a83cc338 added: #setUp
Stefan Vogel <sv@exept.de>
parents: 637
diff changeset
    63
    val := s nextLittleEndianNumber:4.
e1d4a83cc338 added: #setUp
Stefan Vogel <sv@exept.de>
parents: 637
diff changeset
    64
    self assert:val = 16r04030201.
636
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    65
    self assert:( s atEnd ).
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    66
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    67
    self assert:( val := #[16r81 16r82 16r83 16r84] readStream nextLittleEndianNumber:4 ) = 16r84838281.
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    68
    self assert:( val := #[16r81 16r82 16r83 16r84 16r85 16r86 16r87 16r88] readStream nextLittleEndianNumber:8 ) = 16r8887868584838281.
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    69
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    70
    "/ signed
952
e9e3c9e81bb1 class: RegressionTests::StreamTests
Stefan Vogel <sv@exept.de>
parents: 676
diff changeset
    71
    self assert:( val := #[16r01 16r02 16r03 16r04] readStream nextLongMSB:true ) = 16r01020304.
e9e3c9e81bb1 class: RegressionTests::StreamTests
Stefan Vogel <sv@exept.de>
parents: 676
diff changeset
    72
    self assert:( val := #[16rFF 16rFF 16rFF 16rFF] readStream nextLongMSB:true ) = -1.
e9e3c9e81bb1 class: RegressionTests::StreamTests
Stefan Vogel <sv@exept.de>
parents: 676
diff changeset
    73
    self assert:( val := #[16r80 16r00 16r00 16r00] readStream nextLongMSB:true ) = -2147483648.
636
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    74
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    75
    s := WriteStream on:ByteArray new.
952
e9e3c9e81bb1 class: RegressionTests::StreamTests
Stefan Vogel <sv@exept.de>
parents: 676
diff changeset
    76
    s nextPutLong:16r01020304 MSB:true.
636
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    77
    self assert:( val := s contents ) = #[16r01 16r02 16r03 16r04].
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    78
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    79
    s := WriteStream on:ByteArray new.
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    80
    s nextLittleEndianNumber:4 put:16r01020304.
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    81
    self assert:( val := s contents ) = #[16r04 16r03 16r02 16r01].
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    82
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    83
    s := WriteStream on:ByteArray new.
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    84
    s nextLittleEndianNumber:8 put:16r0102030405060708.
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    85
    self assert:( val := s contents ) = #[16r08 16r07 16r06 16r05 16r04 16r03 16r02 16r01].
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    86
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    87
    "
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    88
     self run:#test01_numberReading
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    89
     self new test01_numberReading
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    90
    "
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    91
637
9dbf4cbf5bea added: #test01_numberReading_squeak
Claus Gittinger <cg@exept.de>
parents: 636
diff changeset
    92
    "Created: / 16-09-2011 / 15:26:10 / cg"
1213
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
    93
!
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
    94
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
    95
test02_readStream
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
    96
    {
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
    97
        #($a $b $c $d $a $b $c $d $a $b $c $d $a $b $c $d) .
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
    98
        #[97 98 99 100 97 98 99 100 97 98 99 100]          .
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
    99
        'abcdabcdabcdabcd'                                 .
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   100
        'abcdabcdabcdabcd' asUnicode16String               .
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   101
        'abcdabcdabcdabcd' asUnicode32String               .
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   102
    } do:[:coll|
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   103
        |s e t|
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   104
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   105
        s := coll readStream.
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   106
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   107
        "/ initial state?
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   108
        self assert:(s atEnd not).
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   109
        self assert:(s position == 0).
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   110
        "/ peek returns the correct value
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   111
        e := s peek.
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   112
        self assert:(e asInteger == 97).
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   113
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   114
        "/ peek should not change any state
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   115
        self assert:(s atEnd not).
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   116
        self assert:(s position == 0).
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   117
        e := s next.
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   118
        self assert:(e asInteger == 97).
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   119
        self assert:(s position == 1).
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   120
        self assert:(s atEnd not).
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   121
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   122
        e := s peek.
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   123
        self assert:(s position == 1).
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   124
        self assert:(e asInteger == 98).
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   125
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   126
        s position:0.
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   127
        self assert:(s atEnd not).
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   128
        self assert:(s position == 0).
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   129
        e := s peek.
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   130
        self assert:(e asInteger == 97).
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   131
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   132
        s position:coll size.
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   133
        self assert:(s atEnd).
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   134
        self assert:(s position == coll size).
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   135
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   136
        s position:0.
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   137
        self assert:(s position == 0).
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   138
        e := s peek.
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   139
        self assert:(e asInteger == 97).
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   140
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   141
        t := s next:2.
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   142
        self assert:(t size == 2).
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   143
        self assert:(t at:1) asInteger == 97.
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   144
        self assert:(t at:2) asInteger == 98.
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   145
        self assert:(s position == 2).
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   146
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   147
        s position:1.
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   148
        self assert:(s position == 1).
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   149
        e := s peek.
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   150
        self assert:(e asInteger == 98).
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   151
        t := s upTo:(coll at:1).
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   152
        self assert:(t size == 3).
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   153
        self assert:(t at:1) == (coll at:2).
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   154
        self assert:(t at:2) == (coll at:3).
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   155
        self assert:(t at:3) == (coll at:4).
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   156
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   157
        self assert:(s position == 5).
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   158
        self assert:(s peek asInteger == (coll at:2) asInteger).
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   159
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   160
        s position:1.
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   161
        (coll at:1) isCharacter ifTrue:[
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   162
            s skipSeparators.
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   163
            self assert:(s position == 1).
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   164
        ].
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   165
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   166
        s position:(coll size - 1).
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   167
        t := s upToEnd.
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   168
        self assert:(s position == coll size).
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   169
        self assert:(t size == 1).
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   170
        self assert:(t at:1) == (coll at:coll size).
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   171
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   172
        s position:0.
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   173
        (coll at:1) isCharacter ifTrue:[
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   174
            t := s nextAlphaNumericWord.
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   175
            self assert:(t asArray = coll asArray).
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   176
            self assert:(s position == coll size).
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   177
        ].
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   178
        
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   179
    ].
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   180
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   181
    "
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   182
     self run:#test02_readStream
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   183
     self new test02_readStream
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   184
    "
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   185
!
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   186
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   187
test03_readStream
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   188
    {
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   189
        #($a $b $c $d $ $a $b $c $d $a $b $c $d $a $b $c $d) .
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   190
        #[97 98 99 100 20 97 98 99 100 97 98 99 100]          .
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   191
        'abcd abcdabcdabcd'                                 .
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   192
        'abcd abcdabcdabcd' asUnicode16String               .
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   193
        'abcd abcdabcdabcd' asUnicode32String               .
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   194
    } do:[:coll|
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   195
        |s e t|
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   196
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   197
        s := coll readStream.
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   198
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   199
        s position:3.
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   200
        (coll at:1) isCharacter ifTrue:[
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   201
            s skipSeparators.
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   202
            self assert:(s position == 3).
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   203
            s next.
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   204
            s skipSeparators.
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   205
            self assert:(s position == 5).
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   206
        ].
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   207
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   208
        s position:0.
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   209
        (coll at:1) isCharacter ifTrue:[
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   210
            t := s nextAlphaNumericWord.
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   211
            self assert:(t asArray = (coll asArray copyTo:4)).
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   212
            self assert:(s position == 4).
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   213
        ].
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   214
        
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   215
    ].
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   216
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   217
    "
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   218
     self run:#test02_readStream
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   219
     self new test02_readStream
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   220
    "
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   221
!
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   222
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   223
test04_readIntegers
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   224
    |s n|
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   225
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   226
         "0123456789012345678901"
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   227
    s := '1234 56789    123    ' readStream.
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   228
    self assert:((n := s nextDecimalInteger) == 1234).
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   229
    self assert:(s position == 4).
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   230
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   231
    s skipSeparators.
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   232
    self assert:(s position == 5).
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   233
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   234
    self assert:((n := s nextDecimalInteger) == 56789).
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   235
    self assert:(s position == 10).
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   236
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   237
    s skipSeparators.
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   238
    self assert:(s position == 14).
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   239
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   240
    self assert:((n := s nextDecimalInteger) == 123).
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   241
    self assert:(s position == 17).
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   242
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   243
    "/ is this the correct behavior?
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   244
    self assert:((n := s nextDecimalInteger) == 0).
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   245
    self assert:(s position == 17).
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   246
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   247
    "
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   248
     self run:#test04_readIntegers
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   249
     self new test04_readIntegers
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   250
    "
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   251
!
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   252
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   253
test05_readAlphanumericWords
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   254
    |s w|
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   255
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   256
         "0123456789012345678901"
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   257
    s := 'a234 b6789    c23    ' readStream.
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   258
    self assert:((w := s nextAlphaNumericWord) = 'a234').
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   259
    self assert:(s position == 4).
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   260
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   261
    self assert:((w := s nextAlphaNumericWord) = 'b6789').
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   262
    self assert:(s position == 10).
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   263
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   264
    self assert:((w := s nextAlphaNumericWord) = 'c23').
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   265
    self assert:(s position == 17).
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   266
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   267
    "/ is this the correct behavior?
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   268
    self assert:((w := s nextAlphaNumericWord) isNil).
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   269
    self assert:(s position == 21).
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   270
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   271
    "
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   272
     self run:#test05_readAlphanumericWords
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   273
     self new test05_readAlphanumericWords
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   274
    "
1249
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   275
!
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   276
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   277
test06_writeStream
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   278
    |s|
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   279
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   280
         "0123456789012345678901"
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   281
    s := WriteStream on:(String new).
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   282
    self assert:(s position == 0).
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   283
    self assert:(s readLimit == 0).
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   284
    s nextPut:$a.
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   285
    self assert:(s position == 1).
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   286
    self assert:(s contents = 'a').
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   287
    self assert:(s readLimit == 1).
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   288
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   289
    s nextPut:$b.
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   290
    self assert:(s position == 2).
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   291
    self assert:(s contents = 'ab').
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   292
    self assert:(s readLimit == 2).
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   293
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   294
    s nextPut:$c.
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   295
    self assert:(s position == 3).
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   296
    "/ self assert:(s contents = 'abc').
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   297
    self assert:(s readLimit == 3).
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   298
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   299
    "/ fill to right before it has to resize
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   300
    s position to:(s collection size) do:[:i | s nextPut:$0+(i\\10)].
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   301
    self assert:(s contents = ('abc345678901234567890' copyTo:s size)).
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   302
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   303
    "
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   304
     self run:#test06_writeStream
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   305
     self new test06_writeStream
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   306
    "
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   307
!
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   308
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   309
test07_writeStream
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   310
    |s|
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   311
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   312
         "0123456789012345678901"
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   313
    s := '' writeStream.
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   314
    s nextPut:$a.
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   315
    self assert:(s last) == $a.       
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   316
    self assert:(s last:1) = 'a'.       
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   317
    s nextPut:$b.
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   318
    self assert:(s last) == $b.       
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   319
    self assert:(s last:1) = 'b'.       
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   320
    self assert:(s last:2) = 'ab'.       
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   321
    s nextPut:$c.
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   322
    self assert:(s last) == $c.       
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   323
    self assert:(s last:1) = 'c'.       
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   324
    self assert:(s last:2) = 'bc'.       
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   325
    self assert:(s last:3) = 'abc'.       
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   326
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   327
    s nextPutAll:'123'.
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   328
    self assert:(s last) == $3.       
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   329
    self assert:(s last:1) = '3'.       
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   330
    self assert:(s last:2) = '23'.       
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   331
    self assert:(s last:3) = '123'.       
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   332
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   333
    s next:1 put:$4.
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   334
    self assert:(s last) == $4.       
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   335
    self assert:(s last:1) = '4'.       
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   336
    self assert:(s last:2) = '34'.       
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   337
    self assert:(s last:3) = '234'.       
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   338
    self assert:(s size == 7).       
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   339
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   340
    s next:3 put:$5.
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   341
    self assert:(s last) == $5.       
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   342
    self assert:(s last:1) = '5'.       
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   343
    self assert:(s last:2) = '55'.       
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   344
    self assert:(s last:3) = '555'.       
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   345
    self assert:(s last:4) = '4555'.       
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   346
    self assert:(s size == 10).       
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   347
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   348
    "
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   349
     self run:#test07_writeStream
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   350
     self new test07_writeStream
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   351
    "
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   352
!
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   353
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   354
test08_writeStream
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   355
    |s|
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   356
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   357
    s := '' writeStream.
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   358
    s nextPutAll:'hello '.
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   359
    s nextPutAll:'1234world012345' startingAt:5 to:9.
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   360
    self assert:( s contents = 'hello world' ). 
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   361
1250
e428a40b92ce class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1249
diff changeset
   362
    s := '' writeStream.
e428a40b92ce class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1249
diff changeset
   363
    s nextPutAll:'hello'.
e428a40b92ce class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1249
diff changeset
   364
    s space.
e428a40b92ce class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1249
diff changeset
   365
    s nextPutAll:'world'.
e428a40b92ce class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1249
diff changeset
   366
    self assert:( s contents = 'hello world' ). 
e428a40b92ce class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1249
diff changeset
   367
1249
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   368
    "
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   369
     self run:#test08_writeStream
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   370
     self new test08_writeStream
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   371
    "
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   372
!
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   373
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   374
test09_writeStreamErrors
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   375
    |s|
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   376
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   377
    s := '' writeStream.
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   378
    self should:[ s nextPutAll:nil ] raise:Error.
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   379
    self assert:( s contents = '' ). 
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   380
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   381
    "
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   382
     self run:#test09_writeStreamErrors
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   383
     self new test09_writeStreamErrors
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   384
    "
1251
648aad37189b class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1250
diff changeset
   385
!
648aad37189b class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1250
diff changeset
   386
648aad37189b class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1250
diff changeset
   387
test20_readWriteStream
648aad37189b class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1250
diff changeset
   388
    |s ch string|
648aad37189b class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1250
diff changeset
   389
648aad37189b class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1250
diff changeset
   390
         "0123456789012345678901"
648aad37189b class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1250
diff changeset
   391
    s := ReadWriteStream on:(String new).
648aad37189b class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1250
diff changeset
   392
    self assert:(s position == 0).
648aad37189b class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1250
diff changeset
   393
    self assert:(s readLimit == 0).
648aad37189b class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1250
diff changeset
   394
648aad37189b class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1250
diff changeset
   395
    s nextPutAll:'hello'.
648aad37189b class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1250
diff changeset
   396
    self assert:(s position == 5).
648aad37189b class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1250
diff changeset
   397
    self assert:(s contents = 'hello').
648aad37189b class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1250
diff changeset
   398
    self assert:(s readLimit == 5).
648aad37189b class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1250
diff changeset
   399
1400
3ba502e13bff #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1387
diff changeset
   400
    s nextPut:Character space.
3ba502e13bff #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1387
diff changeset
   401
    self assert:(s position == 6).
3ba502e13bff #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1387
diff changeset
   402
    self assert:(s contents = 'hello ').
3ba502e13bff #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1387
diff changeset
   403
    self assert:(s readLimit == 6).
3ba502e13bff #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1387
diff changeset
   404
3ba502e13bff #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1387
diff changeset
   405
    s nextPutAll:'world'.
1251
648aad37189b class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1250
diff changeset
   406
    self assert:(s position == 11).
648aad37189b class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1250
diff changeset
   407
    self assert:(s contents = 'hello world').
648aad37189b class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1250
diff changeset
   408
    self assert:(s readLimit == 11).
648aad37189b class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1250
diff changeset
   409
648aad37189b class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1250
diff changeset
   410
    s reset.
648aad37189b class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1250
diff changeset
   411
    self assert:(s position == 0).
648aad37189b class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1250
diff changeset
   412
    self assert:(s readLimit == 11).
648aad37189b class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1250
diff changeset
   413
648aad37189b class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1250
diff changeset
   414
    ch := s next.
648aad37189b class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1250
diff changeset
   415
    self assert:(ch == $h).
648aad37189b class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1250
diff changeset
   416
    string := s next:4.
648aad37189b class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1250
diff changeset
   417
    self assert:(string = 'ello').
648aad37189b class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1250
diff changeset
   418
    s reset.
648aad37189b class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1250
diff changeset
   419
    self assert:(s position == 0).
648aad37189b class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1250
diff changeset
   420
    self assert:(s readLimit == 11).
648aad37189b class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1250
diff changeset
   421
648aad37189b class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1250
diff changeset
   422
    string := s upToEnd.
648aad37189b class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1250
diff changeset
   423
    self assert:(string = 'hello world').
648aad37189b class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1250
diff changeset
   424
648aad37189b class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1250
diff changeset
   425
    "
648aad37189b class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1250
diff changeset
   426
     self run:#test20_readWriteStream
648aad37189b class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1250
diff changeset
   427
     self new test20_readWriteStream
648aad37189b class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1250
diff changeset
   428
    "
1309
546f3f8c980f #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1278
diff changeset
   429
!
546f3f8c980f #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1278
diff changeset
   430
1400
3ba502e13bff #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1387
diff changeset
   431
test21_readWriteStreamWithPosition
3ba502e13bff #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1387
diff changeset
   432
    |s|
3ba502e13bff #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1387
diff changeset
   433
1487
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1486
diff changeset
   434
         "0123456789012345678901"
1400
3ba502e13bff #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1387
diff changeset
   435
    s := ReadWriteStream on:(String new).
3ba502e13bff #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1387
diff changeset
   436
    self assert:(s position == 0).
3ba502e13bff #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1387
diff changeset
   437
    self assert:(s readLimit == 0).
3ba502e13bff #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1387
diff changeset
   438
3ba502e13bff #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1387
diff changeset
   439
    s nextPutAll:'hello'.
3ba502e13bff #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1387
diff changeset
   440
    self assert:(s position == 5).
3ba502e13bff #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1387
diff changeset
   441
    self assert:(s readLimit == 5).
3ba502e13bff #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1387
diff changeset
   442
3ba502e13bff #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1387
diff changeset
   443
    s nextPutAll:' world'.
3ba502e13bff #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1387
diff changeset
   444
    self assert:(s position == 11).
3ba502e13bff #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1387
diff changeset
   445
    self assert:(s readLimit == 11).
3ba502e13bff #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1387
diff changeset
   446
3ba502e13bff #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1387
diff changeset
   447
    s position:(s position - 5).
3ba502e13bff #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1387
diff changeset
   448
    self assert:(s upToEnd = 'world').
3ba502e13bff #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1387
diff changeset
   449
    self assert:(s position = 11).
3ba502e13bff #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1387
diff changeset
   450
    self assert:(s readLimit = 11).
3ba502e13bff #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1387
diff changeset
   451
3ba502e13bff #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1387
diff changeset
   452
    "
3ba502e13bff #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1387
diff changeset
   453
     self run:#test21_readWriteStreamWithPosition
3ba502e13bff #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1387
diff changeset
   454
     self new test21_readWriteStreamWithPosition
3ba502e13bff #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1387
diff changeset
   455
    "
3ba502e13bff #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1387
diff changeset
   456
!
3ba502e13bff #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1387
diff changeset
   457
1401
f21e33b07c13 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
   458
test22_readWriteStreamWithRewrite
f21e33b07c13 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
   459
    |s|
f21e33b07c13 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
   460
1487
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1486
diff changeset
   461
         "0123456789012345678901"
1401
f21e33b07c13 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
   462
    s := ReadWriteStream on:(String new).
f21e33b07c13 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
   463
    self assert:(s position == 0).
f21e33b07c13 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
   464
    self assert:(s readLimit == 0).
f21e33b07c13 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
   465
f21e33b07c13 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
   466
    s nextPutAll:'hello world'.
f21e33b07c13 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
   467
    self assert:(s position == 11).
f21e33b07c13 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
   468
    self assert:(s readLimit == 11).
f21e33b07c13 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
   469
f21e33b07c13 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
   470
    s position:(s position - 5).
f21e33b07c13 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
   471
    self assert:(s position = 6).
f21e33b07c13 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
   472
    s nextPutAll:'W'.
1487
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1486
diff changeset
   473
    
1401
f21e33b07c13 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
   474
    self assert:(s position = 7).
f21e33b07c13 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
   475
    self assert:(s readLimit = 11).
f21e33b07c13 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
   476
    self assert:(s contents = 'hello World').
f21e33b07c13 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
   477
1487
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1486
diff changeset
   478
    
1401
f21e33b07c13 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
   479
    "
f21e33b07c13 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
   480
     self run:#test22_readWriteStreamWithRewrite
f21e33b07c13 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
   481
     self new test21_readWriteStreamWithPosition
f21e33b07c13 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
   482
    "
f21e33b07c13 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
   483
!
f21e33b07c13 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
   484
1309
546f3f8c980f #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1278
diff changeset
   485
test30_readWriteBinary
1490
67b5afb7f5ce Fixes StreamTests: Use temporary test filename rather than hardcoded name
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1487
diff changeset
   486
    |testVector f s val|
1309
546f3f8c980f #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1278
diff changeset
   487
546f3f8c980f #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1278
diff changeset
   488
    #(
1480
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1278
diff changeset
   489
        0       #[ 0 0 ]
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1278
diff changeset
   490
        1       #[ 0 1 ]
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1278
diff changeset
   491
        16r7F   #[ 0 16r7F ]
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1278
diff changeset
   492
        16r80   #[ 0 16r80 ]
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1278
diff changeset
   493
        16rFF   #[ 0 16rFF ]
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1278
diff changeset
   494
        16r100  #[ 1 16r00 ]
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1278
diff changeset
   495
        16r7FFF #[ 16r7F 16rFF ]
1309
546f3f8c980f #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1278
diff changeset
   496
546f3f8c980f #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1278
diff changeset
   497
       -1       #[ 16rFF 16rFF ]
546f3f8c980f #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1278
diff changeset
   498
       -16r7F   #[ 16rFF 16r81 ]
546f3f8c980f #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1278
diff changeset
   499
       -16r80   #[ 16rFF 16r80 ]
546f3f8c980f #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1278
diff changeset
   500
       -16rFF   #[ 16rFF 16r01 ]
546f3f8c980f #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1278
diff changeset
   501
       -16r7FFF #[ 16r80 16r01 ]
546f3f8c980f #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1278
diff changeset
   502
       -16r8000 #[ 16r80 16r00 ]
1480
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1278
diff changeset
   503
    ) pairWiseDo:[:val :expected |    
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1278
diff changeset
   504
        s := WriteStream on:(ByteArray new).
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1278
diff changeset
   505
        s nextPutShort:val MSB:true.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1278
diff changeset
   506
        self assert:(s contents = expected).
1309
546f3f8c980f #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1278
diff changeset
   507
1480
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1278
diff changeset
   508
        s := WriteStream on:(ByteArray new).
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1278
diff changeset
   509
        s nextPutShort:val MSB:false.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1278
diff changeset
   510
        self assert:(s contents reversed = expected).
1311
b45b95e640f9 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1310
diff changeset
   511
1490
67b5afb7f5ce Fixes StreamTests: Use temporary test filename rather than hardcoded name
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1487
diff changeset
   512
        f := Filename newTemporary.
1480
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1278
diff changeset
   513
        [    
1490
67b5afb7f5ce Fixes StreamTests: Use temporary test filename rather than hardcoded name
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1487
diff changeset
   514
            s := f writeStream.
1480
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1278
diff changeset
   515
            s nextPutShort:val MSB:true.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1278
diff changeset
   516
            s close.
1490
67b5afb7f5ce Fixes StreamTests: Use temporary test filename rather than hardcoded name
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1487
diff changeset
   517
            self assert:(f binaryContentsOfEntireFile = expected).
1311
b45b95e640f9 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1310
diff changeset
   518
1490
67b5afb7f5ce Fixes StreamTests: Use temporary test filename rather than hardcoded name
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1487
diff changeset
   519
            s := f writeStream.
1480
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1278
diff changeset
   520
            s nextPutShort:val MSB:false.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1278
diff changeset
   521
            s close.
1490
67b5afb7f5ce Fixes StreamTests: Use temporary test filename rather than hardcoded name
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1487
diff changeset
   522
            self assert:(f binaryContentsOfEntireFile reversed = expected).
1480
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1278
diff changeset
   523
        ] ensure:[
1490
67b5afb7f5ce Fixes StreamTests: Use temporary test filename rather than hardcoded name
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1487
diff changeset
   524
            f delete
1480
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1278
diff changeset
   525
        ].    
1309
546f3f8c980f #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1278
diff changeset
   526
    ].
1480
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1278
diff changeset
   527
    
1310
f98c9b95f3e7 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1309
diff changeset
   528
    #(
1480
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1278
diff changeset
   529
        nextPutShort:MSB:   nextShortMSB:
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1278
diff changeset
   530
        nextPutLong:MSB:    nextLongMSB:
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1278
diff changeset
   531
        nextPutHyper:MSB:   nextHyperMSB:
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1278
diff changeset
   532
        
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1278
diff changeset
   533
        nextPutInt16:MSB:   nextInt16MSB:
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1278
diff changeset
   534
        nextPutInt32:MSB:   nextInt32MSB:
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1278
diff changeset
   535
        nextPutInt64:MSB:   nextInt64MSB:
1310
f98c9b95f3e7 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1309
diff changeset
   536
    ) pairWiseDo:[:writer :reader |
1480
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1278
diff changeset
   537
        #(true false) do:[:msb |
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1278
diff changeset
   538
            testVector := 
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1278
diff changeset
   539
                #(
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1278
diff changeset
   540
                    0 1 -1
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1278
diff changeset
   541
                    16r7f 16r80 16r81
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1278
diff changeset
   542
                    -16r7f -16r80 -16r81
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1278
diff changeset
   543
                    16r7fff -16r7fff -16r8000
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1278
diff changeset
   544
                ).
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1278
diff changeset
   545
                 
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1278
diff changeset
   546
            s := ReadWriteStream on:(ByteArray new).
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1278
diff changeset
   547
            testVector do:[:written |
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1278
diff changeset
   548
                s perform:writer with:written with:msb.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1278
diff changeset
   549
            ].
1309
546f3f8c980f #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1278
diff changeset
   550
1480
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1278
diff changeset
   551
            s reset.
1309
546f3f8c980f #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1278
diff changeset
   552
1480
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1278
diff changeset
   553
            testVector do:[:expected |
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1278
diff changeset
   554
                self assert:(val := s perform:reader with:msb) == expected.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1278
diff changeset
   555
            ].
1311
b45b95e640f9 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1310
diff changeset
   556
1480
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1278
diff changeset
   557
            "/ ----
1490
67b5afb7f5ce Fixes StreamTests: Use temporary test filename rather than hardcoded name
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1487
diff changeset
   558
            f := Filename newTemporary.
1480
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1278
diff changeset
   559
            [
1490
67b5afb7f5ce Fixes StreamTests: Use temporary test filename rather than hardcoded name
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1487
diff changeset
   560
                s := f writeStream.
1480
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1278
diff changeset
   561
                testVector do:[:written |
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1278
diff changeset
   562
                    s perform:writer with:written with:msb.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1278
diff changeset
   563
                ].
1311
b45b95e640f9 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1310
diff changeset
   564
1480
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1278
diff changeset
   565
                s close.
1490
67b5afb7f5ce Fixes StreamTests: Use temporary test filename rather than hardcoded name
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1487
diff changeset
   566
                s := f readStream.
1311
b45b95e640f9 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1310
diff changeset
   567
1480
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1278
diff changeset
   568
                testVector do:[:expected |
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1278
diff changeset
   569
                    self assert:(val := s perform:reader with:msb) == expected.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1278
diff changeset
   570
                ].
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1278
diff changeset
   571
                s close.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1278
diff changeset
   572
            ] ensure:[
1490
67b5afb7f5ce Fixes StreamTests: Use temporary test filename rather than hardcoded name
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1487
diff changeset
   573
                f delete
1480
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1278
diff changeset
   574
            ]
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1278
diff changeset
   575
        ].
1309
546f3f8c980f #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1278
diff changeset
   576
    ].
1480
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1278
diff changeset
   577
    
1309
546f3f8c980f #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1278
diff changeset
   578
    "
546f3f8c980f #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1278
diff changeset
   579
     self run:#test30_readWriteBinary
546f3f8c980f #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1278
diff changeset
   580
     self new test30_readWriteBinary
546f3f8c980f #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1278
diff changeset
   581
    "
1490
67b5afb7f5ce Fixes StreamTests: Use temporary test filename rather than hardcoded name
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1487
diff changeset
   582
67b5afb7f5ce Fixes StreamTests: Use temporary test filename rather than hardcoded name
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1487
diff changeset
   583
    "Modified: / 13-05-2016 / 21:21:36 / Jan Vrany <jan.vrany@fit.cvut.cz>"
1387
4ea7fe91cef7 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1311
diff changeset
   584
!
4ea7fe91cef7 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1311
diff changeset
   585
4ea7fe91cef7 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1311
diff changeset
   586
test31_readWriteBinaryIntegers
1490
67b5afb7f5ce Fixes StreamTests: Use temporary test filename rather than hardcoded name
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1487
diff changeset
   587
    |f s|
1387
4ea7fe91cef7 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1311
diff changeset
   588
4ea7fe91cef7 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1311
diff changeset
   589
    #(
1486
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1480
diff changeset
   590
        0       1 #[ 0 ]
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1480
diff changeset
   591
        0       2 #[ 0 0 ]
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1480
diff changeset
   592
        0       3 #[ 0 0 0 ]
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1480
diff changeset
   593
        0       4 #[ 0 0 0 0]
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1480
diff changeset
   594
        0       6 #[ 0 0 0 0 0 0]
1387
4ea7fe91cef7 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1311
diff changeset
   595
1486
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1480
diff changeset
   596
        1       1 #[ 1 ]
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1480
diff changeset
   597
        1       2 #[ 0 1 ]
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1480
diff changeset
   598
        1       3 #[ 0 0 1 ]
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1480
diff changeset
   599
        1       4 #[ 0 0 0 1 ]
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1480
diff changeset
   600
        1       6 #[ 0 0 0 0 0 1 ]
1387
4ea7fe91cef7 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1311
diff changeset
   601
4ea7fe91cef7 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1311
diff changeset
   602
       16r8000  2 #[ 16r80 16r00 ]
4ea7fe91cef7 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1311
diff changeset
   603
       16r8000  3 #[ 16r00 16r80 16r00 ]
4ea7fe91cef7 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1311
diff changeset
   604
       16r8000  4 #[ 16r00 16r00 16r80 16r00 ]
4ea7fe91cef7 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1311
diff changeset
   605
       16r8000  5 #[ 16r00 16r00 16r00 16r80 16r00 ]
4ea7fe91cef7 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1311
diff changeset
   606
       16r8000  6 #[ 16r00 16r00 16r00 16r00 16r80 16r00 ]
4ea7fe91cef7 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1311
diff changeset
   607
4ea7fe91cef7 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1311
diff changeset
   608
       16r12345678  4 #[ 16r12 16r34 16r56 16r78 ]
4ea7fe91cef7 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1311
diff changeset
   609
       16r12345678  5 #[ 16r00 16r12 16r34 16r56 16r78 ]
4ea7fe91cef7 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1311
diff changeset
   610
       16r12345678  6 #[ 16r00 16r00 16r12 16r34 16r56 16r78 ]
4ea7fe91cef7 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1311
diff changeset
   611
4ea7fe91cef7 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1311
diff changeset
   612
       16r87654321  4 #[ 16r87 16r65 16r43 16r21 ]
4ea7fe91cef7 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1311
diff changeset
   613
       16r87654321  5 #[ 16r00 16r87 16r65 16r43 16r21 ]
4ea7fe91cef7 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1311
diff changeset
   614
       16r87654321  6 #[ 16r00 16r00 16r87 16r65 16r43 16r21 ]
4ea7fe91cef7 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1311
diff changeset
   615
1486
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1480
diff changeset
   616
    ) inGroupsOf:3 do:[:val :nBytes :expected |    
1387
4ea7fe91cef7 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1311
diff changeset
   617
1486
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1480
diff changeset
   618
        s := WriteStream on:(ByteArray new).
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1480
diff changeset
   619
        s nextNumber:nBytes put:val MSB:true.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1480
diff changeset
   620
        self assert:(s contents = expected).
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1480
diff changeset
   621
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1480
diff changeset
   622
        s := WriteStream on:(ByteArray new).
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1480
diff changeset
   623
        s nextNumber:nBytes put:val MSB:false.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1480
diff changeset
   624
        self assert:(s contents reversed = expected).
1387
4ea7fe91cef7 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1311
diff changeset
   625
1486
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1480
diff changeset
   626
        "/ because external streams may have specially tuned output methods,
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1480
diff changeset
   627
        "/ test them also
1490
67b5afb7f5ce Fixes StreamTests: Use temporary test filename rather than hardcoded name
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1487
diff changeset
   628
        f := Filename newTemporary.
1486
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1480
diff changeset
   629
        [    
1490
67b5afb7f5ce Fixes StreamTests: Use temporary test filename rather than hardcoded name
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1487
diff changeset
   630
            s := f writeStream.
1486
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1480
diff changeset
   631
            s nextNumber:nBytes put:val MSB:true.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1480
diff changeset
   632
            s close.
1490
67b5afb7f5ce Fixes StreamTests: Use temporary test filename rather than hardcoded name
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1487
diff changeset
   633
            self assert:(f binaryContentsOfEntireFile = expected).
1387
4ea7fe91cef7 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1311
diff changeset
   634
1490
67b5afb7f5ce Fixes StreamTests: Use temporary test filename rather than hardcoded name
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1487
diff changeset
   635
            s := f writeStream.
1486
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1480
diff changeset
   636
            s nextNumber:nBytes put:val MSB:false.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1480
diff changeset
   637
            s close.
1490
67b5afb7f5ce Fixes StreamTests: Use temporary test filename rather than hardcoded name
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1487
diff changeset
   638
            self assert:(f binaryContentsOfEntireFile reversed = expected).
1486
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1480
diff changeset
   639
        ] ensure:[
1490
67b5afb7f5ce Fixes StreamTests: Use temporary test filename rather than hardcoded name
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1487
diff changeset
   640
            f delete
1486
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1480
diff changeset
   641
        ].    
1387
4ea7fe91cef7 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1311
diff changeset
   642
    ].
1486
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1480
diff changeset
   643
    
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1480
diff changeset
   644
    
1387
4ea7fe91cef7 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1311
diff changeset
   645
    "
4ea7fe91cef7 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1311
diff changeset
   646
     self run:#test31_readWriteBinaryIntegers
4ea7fe91cef7 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1311
diff changeset
   647
     self new test31_readWriteBinaryIntegers
4ea7fe91cef7 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1311
diff changeset
   648
    "
1490
67b5afb7f5ce Fixes StreamTests: Use temporary test filename rather than hardcoded name
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1487
diff changeset
   649
67b5afb7f5ce Fixes StreamTests: Use temporary test filename rather than hardcoded name
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1487
diff changeset
   650
    "Modified: / 13-05-2016 / 21:22:25 / Jan Vrany <jan.vrany@fit.cvut.cz>"
1496
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1490
diff changeset
   651
    
1407
18f5a9e9c677 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1401
diff changeset
   652
!
18f5a9e9c677 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1401
diff changeset
   653
18f5a9e9c677 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1401
diff changeset
   654
test40_eolMode
1409
9c3a10712f3d #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1408
diff changeset
   655
    |fn stream lineEnd contents expected eolModeOfStream check|
9c3a10712f3d #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1408
diff changeset
   656
9c3a10712f3d #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1408
diff changeset
   657
    eolModeOfStream :=
1496
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1490
diff changeset
   658
        [:stream |
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1490
diff changeset
   659
            (stream eolMode == #nl) ifTrue:[
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1490
diff changeset
   660
                lineEnd := String lf.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1490
diff changeset
   661
            ] ifFalse:[
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1490
diff changeset
   662
                (stream eolMode == #crlf) ifTrue:[
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1490
diff changeset
   663
                    lineEnd := String crlf.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1490
diff changeset
   664
                ] ifFalse:[
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1490
diff changeset
   665
                    (stream eolMode == #cr) ifTrue:[
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1490
diff changeset
   666
                        lineEnd := String return.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1490
diff changeset
   667
                    ] ifFalse:[
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1490
diff changeset
   668
                        self error
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1490
diff changeset
   669
                    ].    
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1490
diff changeset
   670
                ].    
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1490
diff changeset
   671
            ].    
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1490
diff changeset
   672
        ].
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1490
diff changeset
   673
        
1409
9c3a10712f3d #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1408
diff changeset
   674
    [
1496
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1490
diff changeset
   675
        fn := Filename newTemporary.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1490
diff changeset
   676
        stream := fn writeStream.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1490
diff changeset
   677
        "/ all show the same default behavior
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1490
diff changeset
   678
        self assert:(stream eolMode == #nl).
1410
bb99d701dde7 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 1409
diff changeset
   679
    ] ensure:[
1496
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1490
diff changeset
   680
        stream close.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1490
diff changeset
   681
        fn delete.  
1407
18f5a9e9c677 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1401
diff changeset
   682
    ].
1496
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1490
diff changeset
   683
    
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1490
diff changeset
   684
    check := 
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1490
diff changeset
   685
        [:eolMode |
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1490
diff changeset
   686
            fn := Filename newTemporary.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1490
diff changeset
   687
            stream := fn writeStream.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1490
diff changeset
   688
            stream eolMode:eolMode.
1447
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   689
1496
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1490
diff changeset
   690
            [
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1490
diff changeset
   691
                lineEnd := eolModeOfStream value:stream.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1490
diff changeset
   692
                
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1490
diff changeset
   693
                stream nextPutAll:'line1'; cr.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1490
diff changeset
   694
                stream nextPutLine:'line2'.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1490
diff changeset
   695
                stream nextPutAll:'line3
1409
9c3a10712f3d #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1408
diff changeset
   696
line4'; cr.
1496
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1490
diff changeset
   697
                stream close.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1490
diff changeset
   698
                
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1490
diff changeset
   699
                contents := fn binaryContentsOfEntireFile.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1490
diff changeset
   700
                expected := ('line1*line2*line3*line4*' copyReplaceString:'*' withString:lineEnd) asByteArray.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1490
diff changeset
   701
                
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1490
diff changeset
   702
                self assert:(contents = expected ).
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1490
diff changeset
   703
            ] ensure:[
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1490
diff changeset
   704
                stream close.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1490
diff changeset
   705
                fn delete
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1490
diff changeset
   706
            ].    
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1490
diff changeset
   707
        ].
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1490
diff changeset
   708
    
1409
9c3a10712f3d #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1408
diff changeset
   709
    check value:#lf.
9c3a10712f3d #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1408
diff changeset
   710
    check value:#nl.
9c3a10712f3d #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1408
diff changeset
   711
    check value:#crlf.
9c3a10712f3d #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1408
diff changeset
   712
    check value:#cr.
1496
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1490
diff changeset
   713
    
1407
18f5a9e9c677 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1401
diff changeset
   714
    "
18f5a9e9c677 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1401
diff changeset
   715
     self run:#test40_eolMode
18f5a9e9c677 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1401
diff changeset
   716
     self new test40_eolMode
18f5a9e9c677 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1401
diff changeset
   717
    "
1410
bb99d701dde7 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 1409
diff changeset
   718
bb99d701dde7 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 1409
diff changeset
   719
    "Modified: / 29-04-2016 / 14:20:12 / cg"
636
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   720
! !
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   721
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   722
!StreamTests class methodsFor:'documentation'!
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   723
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   724
version
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   725
    ^ '$Header$'
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   726
!
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   727
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   728
version_CVS
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   729
    ^ '$Header$'
1490
67b5afb7f5ce Fixes StreamTests: Use temporary test filename rather than hardcoded name
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1487
diff changeset
   730
!
67b5afb7f5ce Fixes StreamTests: Use temporary test filename rather than hardcoded name
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1487
diff changeset
   731
67b5afb7f5ce Fixes StreamTests: Use temporary test filename rather than hardcoded name
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1487
diff changeset
   732
version_HG
67b5afb7f5ce Fixes StreamTests: Use temporary test filename rather than hardcoded name
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1487
diff changeset
   733
67b5afb7f5ce Fixes StreamTests: Use temporary test filename rather than hardcoded name
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 1487
diff changeset
   734
    ^ '$Changeset: <not expanded> $'
636
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   735
! !
952
e9e3c9e81bb1 class: RegressionTests::StreamTests
Stefan Vogel <sv@exept.de>
parents: 676
diff changeset
   736