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