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