RegressionTests__StreamTests.st
author Claus Gittinger <cg@exept.de>
Tue, 25 Feb 2020 17:19:18 +0100
changeset 2581 e889c17eef8f
parent 2506 2b717c5ceb95
permissions -rw-r--r--
s
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
2401
b52413a8eca3 #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2206
diff changeset
     1
"{ Encoding: utf8 }"
b52413a8eca3 #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2206
diff changeset
     2
1447
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
     3
"{ Package: 'stx:goodies/regression' }"
636
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     4
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     5
"{ NameSpace: RegressionTests }"
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     6
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     7
TestCase subclass:#StreamTests
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     8
	instanceVariableNames:''
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     9
	classVariableNames:''
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    10
	poolDictionaries:''
1085
29bb4657f206 category change
Claus Gittinger <cg@exept.de>
parents: 952
diff changeset
    11
	category:'tests-Regression-Streams'
636
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    12
!
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    13
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    14
!StreamTests class methodsFor:'documentation'!
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    15
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    16
documentation
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    17
"
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    18
    documentation to be added.
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    19
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    20
    [author:]
1447
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
    21
	cg
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
    [instance variables:]
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    24
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    25
    [class variables:]
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    26
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    27
    [see also:]
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    28
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    29
"
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    30
! !
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    31
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    32
!StreamTests class methodsFor:'queries'!
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    33
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    34
coveredClassNames
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    35
    ^ #(
1447
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
    36
	'PositionableStream'
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
    37
	'ReadStream'
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
    38
	'WriteStream'
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
    39
	'Stream'
636
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    40
    )
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    41
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    42
    "Created: / 16-09-2011 / 14:56:05 / cg"
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    43
! !
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    44
2165
1fc8dd893e6c #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 1897
diff changeset
    45
!StreamTests methodsFor:'initialize / release'!
661
e1d4a83cc338 added: #setUp
Stefan Vogel <sv@exept.de>
parents: 637
diff changeset
    46
e1d4a83cc338 added: #setUp
Stefan Vogel <sv@exept.de>
parents: 637
diff changeset
    47
setUp
e1d4a83cc338 added: #setUp
Stefan Vogel <sv@exept.de>
parents: 637
diff changeset
    48
    (Smalltalk classNamed:'stx_libcompat') isNil ifTrue:[
1447
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
    49
	(Smalltalk loadPackage:'stx:libcompat') ifFalse:[
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
    50
	    self error:'libcompat cannot be loaded'.
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
    51
	].
661
e1d4a83cc338 added: #setUp
Stefan Vogel <sv@exept.de>
parents: 637
diff changeset
    52
    ].
1278
35268b580937 class: RegressionTests::StreamTests
Stefan Vogel <sv@exept.de>
parents: 1270
diff changeset
    53
    (Smalltalk classNamed:'stx_libcompat') load.
661
e1d4a83cc338 added: #setUp
Stefan Vogel <sv@exept.de>
parents: 637
diff changeset
    54
! !
e1d4a83cc338 added: #setUp
Stefan Vogel <sv@exept.de>
parents: 637
diff changeset
    55
636
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    56
!StreamTests methodsFor:'tests'!
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    57
637
9dbf4cbf5bea added: #test01_numberReading_squeak
Claus Gittinger <cg@exept.de>
parents: 636
diff changeset
    58
test01_numberReading_squeak
636
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    59
    |b s val|
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    60
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    61
    b := #[1 2 3 4].
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    62
    s := b readStream.
661
e1d4a83cc338 added: #setUp
Stefan Vogel <sv@exept.de>
parents: 637
diff changeset
    63
    val := s nextLittleEndianNumber:4.
e1d4a83cc338 added: #setUp
Stefan Vogel <sv@exept.de>
parents: 637
diff changeset
    64
    self assert:val = 16r04030201.
636
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    65
    self assert:( s atEnd ).
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    66
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    67
    self assert:( val := #[16r81 16r82 16r83 16r84] readStream nextLittleEndianNumber:4 ) = 16r84838281.
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    68
    self assert:( val := #[16r81 16r82 16r83 16r84 16r85 16r86 16r87 16r88] readStream nextLittleEndianNumber:8 ) = 16r8887868584838281.
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    69
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    70
    "/ signed
2506
2b717c5ceb95 #REFACTORING by exept
Claus Gittinger <cg@exept.de>
parents: 2406
diff changeset
    71
    self assert:( val := #[16r01 16r02 16r03 16r04] readStream nextInt32MSB:true ) = 16r01020304.
2b717c5ceb95 #REFACTORING by exept
Claus Gittinger <cg@exept.de>
parents: 2406
diff changeset
    72
    self assert:( val := #[16rFF 16rFF 16rFF 16rFF] readStream nextInt32MSB:true ) = -1.
2b717c5ceb95 #REFACTORING by exept
Claus Gittinger <cg@exept.de>
parents: 2406
diff changeset
    73
    self assert:( val := #[16r80 16r00 16r00 16r00] readStream nextInt32MSB:true ) = -2147483648.
636
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    74
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    75
    s := WriteStream on:ByteArray new.
952
e9e3c9e81bb1 class: RegressionTests::StreamTests
Stefan Vogel <sv@exept.de>
parents: 676
diff changeset
    76
    s nextPutLong:16r01020304 MSB:true.
636
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    77
    self assert:( val := s contents ) = #[16r01 16r02 16r03 16r04].
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    78
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    79
    s := WriteStream on:ByteArray new.
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    80
    s nextLittleEndianNumber:4 put:16r01020304.
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    81
    self assert:( val := s contents ) = #[16r04 16r03 16r02 16r01].
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    82
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    83
    s := WriteStream on:ByteArray new.
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    84
    s nextLittleEndianNumber:8 put:16r0102030405060708.
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    85
    self assert:( val := s contents ) = #[16r08 16r07 16r06 16r05 16r04 16r03 16r02 16r01].
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    86
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    87
    "
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    88
     self run:#test01_numberReading
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    89
     self new test01_numberReading
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    90
    "
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    91
637
9dbf4cbf5bea added: #test01_numberReading_squeak
Claus Gittinger <cg@exept.de>
parents: 636
diff changeset
    92
    "Created: / 16-09-2011 / 15:26:10 / cg"
1213
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
    93
!
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
    94
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
    95
test02_readStream
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
    96
    {
2404
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
    97
        #($a $b $c $d $a $b $c $d $a $b $c $d $a $b $c $d) .  
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
    98
        #[97 98 99 100 97 98 99 100 97 98 99 100]          .  
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
    99
        'abcdabcdabcdabcd'                                 .  
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
   100
        'abcdabcdabcdabcd' asUnicode16String               . 
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
   101
        'abcdabcdabcdabcd' asUnicode32String               .
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
   102
    } do:[:coll |
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
   103
        |s e t|
1213
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   104
2404
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
   105
        s := coll readStream.
1213
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   106
2404
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
   107
        "/ initial state?
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
   108
        self assert:(s atEnd not).
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
   109
        self assert:(s position == 0).
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
   110
        "/ peek returns the correct value
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
   111
        e := s peek.
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
   112
        self assert:(e asInteger == 97).
1213
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   113
2404
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
   114
        "/ peek should not change any state
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
   115
        self assert:(s atEnd not).
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
   116
        self assert:(s position == 0).
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
   117
        e := s next.
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
   118
        self assert:(e asInteger == 97).
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
   119
        self assert:(s position == 1).
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
   120
        self assert:(s atEnd not).
1213
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   121
2404
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
   122
        e := s peek.
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
   123
        self assert:(s position == 1).
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
   124
        self assert:(e asInteger == 98).
1213
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   125
2404
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
   126
        s position:0.
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
   127
        self assert:(s atEnd not).
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
   128
        self assert:(s position == 0).
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
   129
        e := s peek.
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
   130
        self assert:(e asInteger == 97).
1213
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   131
2404
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
   132
        s position:coll size.
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
   133
        self assert:(s atEnd).
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
   134
        self assert:(s position == coll size).
1213
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   135
2404
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
   136
        s position:0.
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
   137
        self assert:(s position == 0).
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
   138
        e := s peek.
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
   139
        self assert:(e asInteger == 97).
1213
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   140
2404
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
   141
        t := s next:2.
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
   142
        self assert:(t size == 2).
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
   143
        self assert:(t at:1) asInteger == 97.
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
   144
        self assert:(t at:2) asInteger == 98.
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
   145
        self assert:(s position == 2).
1213
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   146
2404
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
   147
        s position:1.
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
   148
        self assert:(s position == 1).
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
   149
        e := s peek.
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
   150
        self assert:(e asInteger == 98).
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
   151
        t := s upTo:(coll at:1).
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
   152
        self assert:(t size == 3).
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
   153
        self assert:(t at:1) == (coll at:2).
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
   154
        self assert:(t at:2) == (coll at:3).
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
   155
        self assert:(t at:3) == (coll at:4).
1213
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   156
2404
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
   157
        self assert:(s position == 5).
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
   158
        self assert:(s peek asInteger == (coll at:2) asInteger).
1213
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   159
2404
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
   160
        s position:1.
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
   161
        (coll at:1) isCharacter ifTrue:[
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
   162
            s skipSeparators.
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
   163
            self assert:(s position == 1).
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
   164
        ].
1213
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   165
2404
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
   166
        s position:(coll size - 1).
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
   167
        t := s upToEnd.
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
   168
        self assert:(s position == coll size).
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
   169
        self assert:(t size == 1).
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
   170
        self assert:(t at:1) == (coll at:coll size).
1213
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   171
2404
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
   172
        s position:0.
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
   173
        (coll at:1) isCharacter ifTrue:[
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
   174
            t := s nextAlphaNumericWord.
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
   175
            self assert:(t asArray = coll asArray).
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
   176
            self assert:(s position == coll size).
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
   177
        ].
1447
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   178
1213
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   179
    ].
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   180
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   181
    "
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   182
     self run:#test02_readStream
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   183
     self new test02_readStream
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   184
    "
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   185
!
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   186
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   187
test03_readStream
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   188
    {
1447
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   189
	#($a $b $c $d $ $a $b $c $d $a $b $c $d $a $b $c $d) .
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   190
	#[97 98 99 100 20 97 98 99 100 97 98 99 100]          .
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   191
	'abcd abcdabcdabcd'                                 .
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   192
	'abcd abcdabcdabcd' asUnicode16String               .
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   193
	'abcd abcdabcdabcd' asUnicode32String               .
1213
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   194
    } do:[:coll|
1447
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   195
	|s e t|
1213
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   196
1447
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   197
	s := coll readStream.
1213
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   198
1447
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   199
	s position:3.
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   200
	(coll at:1) isCharacter ifTrue:[
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   201
	    s skipSeparators.
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   202
	    self assert:(s position == 3).
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   203
	    s next.
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   204
	    s skipSeparators.
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   205
	    self assert:(s position == 5).
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   206
	].
1213
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   207
1447
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   208
	s position:0.
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   209
	(coll at:1) isCharacter ifTrue:[
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   210
	    t := s nextAlphaNumericWord.
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   211
	    self assert:(t asArray = (coll asArray copyTo:4)).
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   212
	    self assert:(s position == 4).
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   213
	].
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   214
1213
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   215
    ].
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   216
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   217
    "
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   218
     self run:#test02_readStream
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   219
     self new test02_readStream
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   220
    "
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   221
!
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   222
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   223
test04_readIntegers
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   224
    |s n|
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   225
1447
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   226
	 "0123456789012345678901"
1213
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   227
    s := '1234 56789    123    ' readStream.
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   228
    self assert:((n := s nextDecimalInteger) == 1234).
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   229
    self assert:(s position == 4).
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   230
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   231
    s skipSeparators.
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   232
    self assert:(s position == 5).
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   233
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   234
    self assert:((n := s nextDecimalInteger) == 56789).
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   235
    self assert:(s position == 10).
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   236
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   237
    s skipSeparators.
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   238
    self assert:(s position == 14).
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   239
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   240
    self assert:((n := s nextDecimalInteger) == 123).
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   241
    self assert:(s position == 17).
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   242
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   243
    "/ is this the correct behavior?
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   244
    self assert:((n := s nextDecimalInteger) == 0).
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   245
    self assert:(s position == 17).
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   246
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   247
    "
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   248
     self run:#test04_readIntegers
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   249
     self new test04_readIntegers
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   250
    "
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   251
!
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   252
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   253
test05_readAlphanumericWords
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   254
    |s w|
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   255
1447
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   256
	 "0123456789012345678901"
1213
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   257
    s := 'a234 b6789    c23    ' readStream.
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   258
    self assert:((w := s nextAlphaNumericWord) = 'a234').
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   259
    self assert:(s position == 4).
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   260
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   261
    self assert:((w := s nextAlphaNumericWord) = 'b6789').
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   262
    self assert:(s position == 10).
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   263
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   264
    self assert:((w := s nextAlphaNumericWord) = 'c23').
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   265
    self assert:(s position == 17).
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   266
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   267
    "/ is this the correct behavior?
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   268
    self assert:((w := s nextAlphaNumericWord) isNil).
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   269
    self assert:(s position == 21).
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   270
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   271
    "
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   272
     self run:#test05_readAlphanumericWords
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   273
     self new test05_readAlphanumericWords
0de4acfc2597 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1085
diff changeset
   274
    "
1249
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   275
!
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   276
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   277
test06_writeStream
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   278
    |s|
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   279
1447
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   280
	 "0123456789012345678901"
1249
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   281
    s := WriteStream on:(String new).
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   282
    self assert:(s position == 0).
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   283
    self assert:(s readLimit == 0).
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   284
    s nextPut:$a.
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   285
    self assert:(s position == 1).
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   286
    self assert:(s contents = 'a').
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   287
    self assert:(s readLimit == 1).
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   288
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   289
    s nextPut:$b.
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   290
    self assert:(s position == 2).
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   291
    self assert:(s contents = 'ab').
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   292
    self assert:(s readLimit == 2).
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   293
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   294
    s nextPut:$c.
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   295
    self assert:(s position == 3).
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   296
    "/ self assert:(s contents = 'abc').
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   297
    self assert:(s readLimit == 3).
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   298
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   299
    "/ fill to right before it has to resize
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   300
    s position to:(s collection size) do:[:i | s nextPut:$0+(i\\10)].
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   301
    self assert:(s contents = ('abc345678901234567890' copyTo:s size)).
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   302
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   303
    "
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   304
     self run:#test06_writeStream
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   305
     self new test06_writeStream
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   306
    "
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   307
!
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   308
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   309
test07_writeStream
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   310
    |s|
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   311
1447
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   312
	 "0123456789012345678901"
1249
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   313
    s := '' writeStream.
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   314
    s nextPut:$a.
1447
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   315
    self assert:(s last) == $a.
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   316
    self assert:(s last:1) = 'a'.
1249
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   317
    s nextPut:$b.
1447
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   318
    self assert:(s last) == $b.
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   319
    self assert:(s last:1) = 'b'.
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   320
    self assert:(s last:2) = 'ab'.
1249
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   321
    s nextPut:$c.
1447
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   322
    self assert:(s last) == $c.
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   323
    self assert:(s last:1) = 'c'.
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   324
    self assert:(s last:2) = 'bc'.
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   325
    self assert:(s last:3) = 'abc'.
1249
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   326
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   327
    s nextPutAll:'123'.
1447
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   328
    self assert:(s last) == $3.
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   329
    self assert:(s last:1) = '3'.
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   330
    self assert:(s last:2) = '23'.
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   331
    self assert:(s last:3) = '123'.
1249
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   332
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   333
    s next:1 put:$4.
1447
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   334
    self assert:(s last) == $4.
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   335
    self assert:(s last:1) = '4'.
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   336
    self assert:(s last:2) = '34'.
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   337
    self assert:(s last:3) = '234'.
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   338
    self assert:(s size == 7).
1249
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   339
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   340
    s next:3 put:$5.
1447
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   341
    self assert:(s last) == $5.
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   342
    self assert:(s last:1) = '5'.
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   343
    self assert:(s last:2) = '55'.
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   344
    self assert:(s last:3) = '555'.
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   345
    self assert:(s last:4) = '4555'.
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   346
    self assert:(s size == 10).
1249
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   347
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   348
    "
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   349
     self run:#test07_writeStream
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   350
     self new test07_writeStream
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   351
    "
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   352
!
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   353
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   354
test08_writeStream
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   355
    |s|
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   356
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   357
    s := '' writeStream.
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   358
    s nextPutAll:'hello '.
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   359
    s nextPutAll:'1234world012345' startingAt:5 to:9.
1447
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   360
    self assert:( s contents = 'hello world' ).
1249
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   361
1250
e428a40b92ce class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1249
diff changeset
   362
    s := '' writeStream.
e428a40b92ce class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1249
diff changeset
   363
    s nextPutAll:'hello'.
e428a40b92ce class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1249
diff changeset
   364
    s space.
e428a40b92ce class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1249
diff changeset
   365
    s nextPutAll:'world'.
1447
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   366
    self assert:( s contents = 'hello world' ).
1250
e428a40b92ce class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1249
diff changeset
   367
1249
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   368
    "
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   369
     self run:#test08_writeStream
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   370
     self new test08_writeStream
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   371
    "
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   372
!
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   373
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   374
test09_writeStreamErrors
2206
827d17b7a941 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   375
    |s didRaise|
1249
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   376
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   377
    s := '' writeStream.
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   378
    self should:[ s nextPutAll:nil ] raise:Error.
1447
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   379
    self assert:( s contents = '' ).
1249
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   380
2206
827d17b7a941 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   381
    "/ write error must be raised
827d17b7a941 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   382
    s := '' writeStream.
827d17b7a941 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   383
    s writeLimit:5.
827d17b7a941 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   384
    didRaise := false.
827d17b7a941 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   385
    WriteError handle:[:ex |
827d17b7a941 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   386
        didRaise := true.
827d17b7a941 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   387
        ex return.
827d17b7a941 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   388
    ] do:[    
827d17b7a941 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   389
        s nextPutAll:'1234567890'.
827d17b7a941 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   390
    ].
827d17b7a941 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   391
    self assert:didRaise.
827d17b7a941 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   392
    self assert:(s contents size == 5).
827d17b7a941 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   393
827d17b7a941 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   394
    "/ try more
827d17b7a941 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   395
    didRaise := false.
827d17b7a941 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   396
    WriteError handle:[:ex |
827d17b7a941 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   397
        didRaise := true.
827d17b7a941 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   398
        ex return.
827d17b7a941 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   399
    ] do:[    
827d17b7a941 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   400
        s nextPut:$6.
827d17b7a941 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   401
    ].
827d17b7a941 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   402
    self assert:didRaise.
827d17b7a941 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   403
    self assert:(s contents size == 5).
827d17b7a941 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   404
827d17b7a941 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   405
    "/ try more
827d17b7a941 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   406
    didRaise := false.
827d17b7a941 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   407
    WriteError handle:[:ex |
827d17b7a941 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   408
        didRaise := true.
827d17b7a941 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   409
        ex return.
827d17b7a941 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   410
    ] do:[    
827d17b7a941 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   411
        s space.
827d17b7a941 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   412
    ].
827d17b7a941 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   413
    self assert:didRaise.
827d17b7a941 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   414
    self assert:(s contents size == 5).
827d17b7a941 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   415
    
827d17b7a941 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   416
    "/ try more
827d17b7a941 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   417
    didRaise := false.
827d17b7a941 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   418
    WriteError handle:[:ex |
827d17b7a941 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   419
        didRaise := true.
827d17b7a941 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   420
        ex return.
827d17b7a941 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   421
    ] do:[    
827d17b7a941 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   422
        s cr.
827d17b7a941 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   423
    ].
827d17b7a941 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   424
    self assert:didRaise.
827d17b7a941 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   425
    self assert:(s contents size == 5).
827d17b7a941 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   426
827d17b7a941 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   427
    "/ try more
827d17b7a941 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   428
    didRaise := false.
827d17b7a941 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   429
    WriteError handle:[:ex |
827d17b7a941 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   430
        didRaise := true.
827d17b7a941 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   431
        ex return.
827d17b7a941 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   432
    ] do:[    
827d17b7a941 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   433
        s next:10 put:$9.
827d17b7a941 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   434
    ].
827d17b7a941 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   435
    self assert:didRaise.
827d17b7a941 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   436
    self assert:(s contents size == 5).
827d17b7a941 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   437
827d17b7a941 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   438
    "/ try more
827d17b7a941 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   439
    didRaise := false.
827d17b7a941 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   440
    WriteError handle:[:ex |
827d17b7a941 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   441
        didRaise := true.
827d17b7a941 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   442
        ex return.
827d17b7a941 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   443
    ] do:[    
827d17b7a941 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   444
        s nextPutAll:'6789012345' startingAt:1 to:10.
827d17b7a941 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   445
    ].
827d17b7a941 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   446
    self assert:didRaise.
827d17b7a941 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   447
    self assert:(s contents size == 5).
827d17b7a941 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   448
827d17b7a941 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   449
    
1249
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   450
    "
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   451
     self run:#test09_writeStreamErrors
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   452
     self new test09_writeStreamErrors
3b882caff8e6 class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1213
diff changeset
   453
    "
2206
827d17b7a941 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   454
827d17b7a941 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2190
diff changeset
   455
    "Modified: / 01-04-2019 / 17:13:40 / Claus Gittinger"
1251
648aad37189b class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1250
diff changeset
   456
!
648aad37189b class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1250
diff changeset
   457
648aad37189b class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1250
diff changeset
   458
test20_readWriteStream
648aad37189b class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1250
diff changeset
   459
    |s ch string|
648aad37189b class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1250
diff changeset
   460
1447
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   461
	 "0123456789012345678901"
1251
648aad37189b class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1250
diff changeset
   462
    s := ReadWriteStream on:(String new).
648aad37189b class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1250
diff changeset
   463
    self assert:(s position == 0).
648aad37189b class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1250
diff changeset
   464
    self assert:(s readLimit == 0).
648aad37189b class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1250
diff changeset
   465
648aad37189b class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1250
diff changeset
   466
    s nextPutAll:'hello'.
648aad37189b class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1250
diff changeset
   467
    self assert:(s position == 5).
648aad37189b class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1250
diff changeset
   468
    self assert:(s contents = 'hello').
648aad37189b class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1250
diff changeset
   469
    self assert:(s readLimit == 5).
648aad37189b class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1250
diff changeset
   470
1400
3ba502e13bff #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1387
diff changeset
   471
    s nextPut:Character space.
3ba502e13bff #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1387
diff changeset
   472
    self assert:(s position == 6).
3ba502e13bff #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1387
diff changeset
   473
    self assert:(s contents = 'hello ').
3ba502e13bff #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1387
diff changeset
   474
    self assert:(s readLimit == 6).
3ba502e13bff #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1387
diff changeset
   475
3ba502e13bff #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1387
diff changeset
   476
    s nextPutAll:'world'.
1251
648aad37189b class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1250
diff changeset
   477
    self assert:(s position == 11).
648aad37189b class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1250
diff changeset
   478
    self assert:(s contents = 'hello world').
648aad37189b class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1250
diff changeset
   479
    self assert:(s readLimit == 11).
648aad37189b class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1250
diff changeset
   480
648aad37189b class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1250
diff changeset
   481
    s reset.
648aad37189b class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1250
diff changeset
   482
    self assert:(s position == 0).
648aad37189b class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1250
diff changeset
   483
    self assert:(s readLimit == 11).
648aad37189b class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1250
diff changeset
   484
648aad37189b class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1250
diff changeset
   485
    ch := s next.
648aad37189b class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1250
diff changeset
   486
    self assert:(ch == $h).
648aad37189b class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1250
diff changeset
   487
    string := s next:4.
648aad37189b class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1250
diff changeset
   488
    self assert:(string = 'ello').
648aad37189b class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1250
diff changeset
   489
    s reset.
648aad37189b class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1250
diff changeset
   490
    self assert:(s position == 0).
648aad37189b class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1250
diff changeset
   491
    self assert:(s readLimit == 11).
648aad37189b class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1250
diff changeset
   492
648aad37189b class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1250
diff changeset
   493
    string := s upToEnd.
648aad37189b class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1250
diff changeset
   494
    self assert:(string = 'hello world').
648aad37189b class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1250
diff changeset
   495
648aad37189b class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1250
diff changeset
   496
    "
648aad37189b class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1250
diff changeset
   497
     self run:#test20_readWriteStream
648aad37189b class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1250
diff changeset
   498
     self new test20_readWriteStream
648aad37189b class: RegressionTests::StreamTests
Claus Gittinger <cg@exept.de>
parents: 1250
diff changeset
   499
    "
1309
546f3f8c980f #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1278
diff changeset
   500
!
546f3f8c980f #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1278
diff changeset
   501
1400
3ba502e13bff #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1387
diff changeset
   502
test21_readWriteStreamWithPosition
3ba502e13bff #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1387
diff changeset
   503
    |s|
3ba502e13bff #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1387
diff changeset
   504
1447
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   505
	 "0123456789012345678901"
1400
3ba502e13bff #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1387
diff changeset
   506
    s := ReadWriteStream on:(String new).
3ba502e13bff #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1387
diff changeset
   507
    self assert:(s position == 0).
3ba502e13bff #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1387
diff changeset
   508
    self assert:(s readLimit == 0).
3ba502e13bff #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1387
diff changeset
   509
3ba502e13bff #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1387
diff changeset
   510
    s nextPutAll:'hello'.
3ba502e13bff #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1387
diff changeset
   511
    self assert:(s position == 5).
3ba502e13bff #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1387
diff changeset
   512
    self assert:(s readLimit == 5).
3ba502e13bff #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1387
diff changeset
   513
3ba502e13bff #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1387
diff changeset
   514
    s nextPutAll:' world'.
3ba502e13bff #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1387
diff changeset
   515
    self assert:(s position == 11).
3ba502e13bff #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1387
diff changeset
   516
    self assert:(s readLimit == 11).
3ba502e13bff #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1387
diff changeset
   517
3ba502e13bff #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1387
diff changeset
   518
    s position:(s position - 5).
3ba502e13bff #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1387
diff changeset
   519
    self assert:(s upToEnd = 'world').
3ba502e13bff #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1387
diff changeset
   520
    self assert:(s position = 11).
3ba502e13bff #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1387
diff changeset
   521
    self assert:(s readLimit = 11).
3ba502e13bff #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1387
diff changeset
   522
3ba502e13bff #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1387
diff changeset
   523
    "
3ba502e13bff #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1387
diff changeset
   524
     self run:#test21_readWriteStreamWithPosition
3ba502e13bff #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1387
diff changeset
   525
     self new test21_readWriteStreamWithPosition
3ba502e13bff #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1387
diff changeset
   526
    "
3ba502e13bff #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1387
diff changeset
   527
!
3ba502e13bff #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1387
diff changeset
   528
1401
f21e33b07c13 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
   529
test22_readWriteStreamWithRewrite
f21e33b07c13 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
   530
    |s|
f21e33b07c13 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
   531
1447
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   532
	 "0123456789012345678901"
1401
f21e33b07c13 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
   533
    s := ReadWriteStream on:(String new).
f21e33b07c13 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
   534
    self assert:(s position == 0).
f21e33b07c13 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
   535
    self assert:(s readLimit == 0).
f21e33b07c13 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
   536
f21e33b07c13 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
   537
    s nextPutAll:'hello world'.
f21e33b07c13 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
   538
    self assert:(s position == 11).
f21e33b07c13 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
   539
    self assert:(s readLimit == 11).
f21e33b07c13 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
   540
f21e33b07c13 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
   541
    s position:(s position - 5).
f21e33b07c13 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
   542
    self assert:(s position = 6).
f21e33b07c13 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
   543
    s nextPutAll:'W'.
1447
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   544
1401
f21e33b07c13 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
   545
    self assert:(s position = 7).
f21e33b07c13 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
   546
    self assert:(s readLimit = 11).
f21e33b07c13 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
   547
    self assert:(s contents = 'hello World').
f21e33b07c13 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
   548
1447
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   549
1401
f21e33b07c13 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
   550
    "
f21e33b07c13 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
   551
     self run:#test22_readWriteStreamWithRewrite
f21e33b07c13 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
   552
     self new test21_readWriteStreamWithPosition
f21e33b07c13 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
   553
    "
f21e33b07c13 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
   554
!
f21e33b07c13 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
   555
1309
546f3f8c980f #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1278
diff changeset
   556
test30_readWriteBinary
546f3f8c980f #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1278
diff changeset
   557
    |testVector s val|
546f3f8c980f #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1278
diff changeset
   558
546f3f8c980f #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1278
diff changeset
   559
    #(
1447
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   560
	0       #[ 0 0 ]
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   561
	1       #[ 0 1 ]
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   562
	16r7F   #[ 0 16r7F ]
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   563
	16r80   #[ 0 16r80 ]
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   564
	16rFF   #[ 0 16rFF ]
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   565
	16r100  #[ 1 16r00 ]
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   566
	16r7FFF #[ 16r7F 16rFF ]
1309
546f3f8c980f #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1278
diff changeset
   567
546f3f8c980f #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1278
diff changeset
   568
       -1       #[ 16rFF 16rFF ]
546f3f8c980f #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1278
diff changeset
   569
       -16r7F   #[ 16rFF 16r81 ]
546f3f8c980f #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1278
diff changeset
   570
       -16r80   #[ 16rFF 16r80 ]
546f3f8c980f #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1278
diff changeset
   571
       -16rFF   #[ 16rFF 16r01 ]
546f3f8c980f #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1278
diff changeset
   572
       -16r7FFF #[ 16r80 16r01 ]
546f3f8c980f #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1278
diff changeset
   573
       -16r8000 #[ 16r80 16r00 ]
1447
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   574
    ) pairWiseDo:[:val :expected |
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   575
	s := WriteStream on:(ByteArray new).
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   576
	s nextPutShort:val MSB:true.
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   577
	self assert:(s contents = expected).
1309
546f3f8c980f #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1278
diff changeset
   578
1447
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   579
	s := WriteStream on:(ByteArray new).
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   580
	s nextPutShort:val MSB:false.
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   581
	self assert:(s contents reversed = expected).
1311
b45b95e640f9 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1310
diff changeset
   582
1447
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   583
	[
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   584
	    s := 'testData' asFilename writeStream.
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   585
	    s nextPutShort:val MSB:true.
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   586
	    s close.
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   587
	    self assert:('testData' asFilename binaryContentsOfEntireFile = expected).
1311
b45b95e640f9 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1310
diff changeset
   588
1447
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   589
	    s := 'testData' asFilename writeStream.
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   590
	    s nextPutShort:val MSB:false.
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   591
	    s close.
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   592
	    self assert:('testData' asFilename binaryContentsOfEntireFile reversed = expected).
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   593
	] ensure:[
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   594
	    'testData' asFilename delete
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   595
	].
1309
546f3f8c980f #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1278
diff changeset
   596
    ].
1447
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   597
1310
f98c9b95f3e7 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1309
diff changeset
   598
    #(
1447
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   599
	nextPutShort:MSB:   nextShortMSB:
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   600
	nextPutLong:MSB:    nextLongMSB:
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   601
	nextPutHyper:MSB:   nextHyperMSB:
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   602
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   603
	nextPutInt16:MSB:   nextInt16MSB:
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   604
	nextPutInt32:MSB:   nextInt32MSB:
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   605
	nextPutInt64:MSB:   nextInt64MSB:
1310
f98c9b95f3e7 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1309
diff changeset
   606
    ) pairWiseDo:[:writer :reader |
1447
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   607
	#(true false) do:[:msb |
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   608
	    testVector :=
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   609
		#(
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   610
		    0 1 -1
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   611
		    16r7f 16r80 16r81
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   612
		    -16r7f -16r80 -16r81
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   613
		    16r7fff -16r7fff -16r8000
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   614
		).
1309
546f3f8c980f #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1278
diff changeset
   615
1447
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   616
	    s := ReadWriteStream on:(ByteArray new).
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   617
	    testVector do:[:written |
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   618
		s perform:writer with:written with:msb.
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   619
	    ].
1309
546f3f8c980f #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1278
diff changeset
   620
1447
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   621
	    s reset.
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   622
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   623
	    testVector do:[:expected |
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   624
		self assert:(val := s perform:reader with:msb) == expected.
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   625
	    ].
1311
b45b95e640f9 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1310
diff changeset
   626
1447
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   627
	    "/ ----
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   628
	    [
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   629
		s := 'testData' asFilename writeStream.
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   630
		testVector do:[:written |
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   631
		    s perform:writer with:written with:msb.
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   632
		].
1311
b45b95e640f9 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1310
diff changeset
   633
1447
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   634
		s close.
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   635
		s := 'testData' asFilename readStream.
1311
b45b95e640f9 #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1310
diff changeset
   636
1447
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   637
		testVector do:[:expected |
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   638
		    self assert:(val := s perform:reader with:msb) == expected.
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   639
		].
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   640
		s close.
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   641
	    ] ensure:[
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   642
		'testData' asFilename delete
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   643
	    ]
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   644
	].
1309
546f3f8c980f #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1278
diff changeset
   645
    ].
1447
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   646
1309
546f3f8c980f #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1278
diff changeset
   647
    "
546f3f8c980f #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1278
diff changeset
   648
     self run:#test30_readWriteBinary
546f3f8c980f #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1278
diff changeset
   649
     self new test30_readWriteBinary
546f3f8c980f #FEATURE
Claus Gittinger <cg@exept.de>
parents: 1278
diff changeset
   650
    "
1387
4ea7fe91cef7 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1311
diff changeset
   651
!
4ea7fe91cef7 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1311
diff changeset
   652
4ea7fe91cef7 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1311
diff changeset
   653
test31_readWriteBinaryIntegers
4ea7fe91cef7 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1311
diff changeset
   654
    |s|
4ea7fe91cef7 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1311
diff changeset
   655
4ea7fe91cef7 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1311
diff changeset
   656
    #(
1447
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   657
	0       1 #[ 0 ]
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   658
	0       2 #[ 0 0 ]
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   659
	0       3 #[ 0 0 0 ]
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   660
	0       4 #[ 0 0 0 0]
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   661
	0       6 #[ 0 0 0 0 0 0]
1387
4ea7fe91cef7 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1311
diff changeset
   662
1447
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   663
	1       1 #[ 1 ]
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   664
	1       2 #[ 0 1 ]
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   665
	1       3 #[ 0 0 1 ]
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   666
	1       4 #[ 0 0 0 1 ]
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   667
	1       6 #[ 0 0 0 0 0 1 ]
1387
4ea7fe91cef7 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1311
diff changeset
   668
4ea7fe91cef7 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1311
diff changeset
   669
       16r8000  2 #[ 16r80 16r00 ]
4ea7fe91cef7 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1311
diff changeset
   670
       16r8000  3 #[ 16r00 16r80 16r00 ]
4ea7fe91cef7 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1311
diff changeset
   671
       16r8000  4 #[ 16r00 16r00 16r80 16r00 ]
4ea7fe91cef7 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1311
diff changeset
   672
       16r8000  5 #[ 16r00 16r00 16r00 16r80 16r00 ]
4ea7fe91cef7 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1311
diff changeset
   673
       16r8000  6 #[ 16r00 16r00 16r00 16r00 16r80 16r00 ]
4ea7fe91cef7 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1311
diff changeset
   674
4ea7fe91cef7 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1311
diff changeset
   675
       16r12345678  4 #[ 16r12 16r34 16r56 16r78 ]
4ea7fe91cef7 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1311
diff changeset
   676
       16r12345678  5 #[ 16r00 16r12 16r34 16r56 16r78 ]
4ea7fe91cef7 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1311
diff changeset
   677
       16r12345678  6 #[ 16r00 16r00 16r12 16r34 16r56 16r78 ]
4ea7fe91cef7 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1311
diff changeset
   678
4ea7fe91cef7 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1311
diff changeset
   679
       16r87654321  4 #[ 16r87 16r65 16r43 16r21 ]
4ea7fe91cef7 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1311
diff changeset
   680
       16r87654321  5 #[ 16r00 16r87 16r65 16r43 16r21 ]
4ea7fe91cef7 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1311
diff changeset
   681
       16r87654321  6 #[ 16r00 16r00 16r87 16r65 16r43 16r21 ]
4ea7fe91cef7 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1311
diff changeset
   682
1447
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   683
    ) inGroupsOf:3 do:[:val :nBytes :expected |
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   684
	s := WriteStream on:(ByteArray new).
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   685
	s nextNumber:nBytes put:val MSB:true.
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   686
	self assert:(s contents = expected).
1387
4ea7fe91cef7 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1311
diff changeset
   687
1447
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   688
	s := WriteStream on:(ByteArray new).
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   689
	s nextNumber:nBytes put:val MSB:false.
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   690
	self assert:(s contents reversed = expected).
1387
4ea7fe91cef7 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1311
diff changeset
   691
1447
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   692
	"/ because external streams may have specially tuned output methods,
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   693
	"/ test them also
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   694
	[
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   695
	    s := 'testData' asFilename writeStream.
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   696
	    s nextNumber:nBytes put:val MSB:true.
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   697
	    s close.
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   698
	    self assert:('testData' asFilename binaryContentsOfEntireFile = expected).
1387
4ea7fe91cef7 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1311
diff changeset
   699
1447
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   700
	    s := 'testData' asFilename writeStream.
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   701
	    s nextNumber:nBytes put:val MSB:false.
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   702
	    s close.
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   703
	    self assert:('testData' asFilename binaryContentsOfEntireFile reversed = expected).
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   704
	] ensure:[
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   705
	    'testData' asFilename delete
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   706
	].
1387
4ea7fe91cef7 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1311
diff changeset
   707
    ].
1447
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   708
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   709
1387
4ea7fe91cef7 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1311
diff changeset
   710
    "
4ea7fe91cef7 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1311
diff changeset
   711
     self run:#test31_readWriteBinaryIntegers
4ea7fe91cef7 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1311
diff changeset
   712
     self new test31_readWriteBinaryIntegers
4ea7fe91cef7 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1311
diff changeset
   713
    "
1407
18f5a9e9c677 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1401
diff changeset
   714
!
18f5a9e9c677 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1401
diff changeset
   715
18f5a9e9c677 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1401
diff changeset
   716
test40_eolMode
1409
9c3a10712f3d #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1408
diff changeset
   717
    |fn stream lineEnd contents expected eolModeOfStream check|
9c3a10712f3d #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1408
diff changeset
   718
9c3a10712f3d #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1408
diff changeset
   719
    eolModeOfStream :=
1548
c945639d2455 #BUGFIX by sr
sr
parents: 1447
diff changeset
   720
        [:stream |
1555
2089b49b4f94 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1548
diff changeset
   721
            |eolMode|
2089b49b4f94 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1548
diff changeset
   722
2089b49b4f94 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1548
diff changeset
   723
            eolMode := stream eolMode.
2089b49b4f94 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1548
diff changeset
   724
            (eolMode == #nl) ifTrue:[
1548
c945639d2455 #BUGFIX by sr
sr
parents: 1447
diff changeset
   725
                lineEnd := String lf.
c945639d2455 #BUGFIX by sr
sr
parents: 1447
diff changeset
   726
            ] ifFalse:[
1555
2089b49b4f94 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1548
diff changeset
   727
                (eolMode == #crlf) ifTrue:[
1548
c945639d2455 #BUGFIX by sr
sr
parents: 1447
diff changeset
   728
                    lineEnd := String crlf.
c945639d2455 #BUGFIX by sr
sr
parents: 1447
diff changeset
   729
                ] ifFalse:[
1555
2089b49b4f94 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1548
diff changeset
   730
                    (eolMode == #cr) ifTrue:[
1548
c945639d2455 #BUGFIX by sr
sr
parents: 1447
diff changeset
   731
                        lineEnd := String return.
c945639d2455 #BUGFIX by sr
sr
parents: 1447
diff changeset
   732
                    ] ifFalse:[
1555
2089b49b4f94 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1548
diff changeset
   733
                        (eolMode == #eot) ifTrue:[
2089b49b4f94 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1548
diff changeset
   734
                            lineEnd := (Character value:4) asString.
2089b49b4f94 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1548
diff changeset
   735
                        ] ifFalse:[
2089b49b4f94 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1548
diff changeset
   736
                            (eolMode == #etx) ifTrue:[
2089b49b4f94 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1548
diff changeset
   737
                                lineEnd := (Character value:3) asString.
2089b49b4f94 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1548
diff changeset
   738
                            ] ifFalse:[
2089b49b4f94 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1548
diff changeset
   739
                                self error
2089b49b4f94 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1548
diff changeset
   740
                            ].
2089b49b4f94 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1548
diff changeset
   741
                        ].
1548
c945639d2455 #BUGFIX by sr
sr
parents: 1447
diff changeset
   742
                    ].
c945639d2455 #BUGFIX by sr
sr
parents: 1447
diff changeset
   743
                ].
c945639d2455 #BUGFIX by sr
sr
parents: 1447
diff changeset
   744
            ].
c945639d2455 #BUGFIX by sr
sr
parents: 1447
diff changeset
   745
        ].
1447
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   746
1409
9c3a10712f3d #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1408
diff changeset
   747
    [
1548
c945639d2455 #BUGFIX by sr
sr
parents: 1447
diff changeset
   748
        fn := Filename newTemporary.
c945639d2455 #BUGFIX by sr
sr
parents: 1447
diff changeset
   749
        stream := fn writeStream.
c945639d2455 #BUGFIX by sr
sr
parents: 1447
diff changeset
   750
        "/ all show the same default behavior
c945639d2455 #BUGFIX by sr
sr
parents: 1447
diff changeset
   751
        OperatingSystem isMSDOSlike ifTrue:[
c945639d2455 #BUGFIX by sr
sr
parents: 1447
diff changeset
   752
            self assert:(stream eolMode == #crlf).
c945639d2455 #BUGFIX by sr
sr
parents: 1447
diff changeset
   753
        ] ifFalse:[
c945639d2455 #BUGFIX by sr
sr
parents: 1447
diff changeset
   754
            self assert:(stream eolMode == #nl).
c945639d2455 #BUGFIX by sr
sr
parents: 1447
diff changeset
   755
        ].
1410
bb99d701dde7 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 1409
diff changeset
   756
    ] ensure:[
1548
c945639d2455 #BUGFIX by sr
sr
parents: 1447
diff changeset
   757
        stream close.
c945639d2455 #BUGFIX by sr
sr
parents: 1447
diff changeset
   758
        fn delete.
1407
18f5a9e9c677 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1401
diff changeset
   759
    ].
1447
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   760
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   761
    check :=
1548
c945639d2455 #BUGFIX by sr
sr
parents: 1447
diff changeset
   762
        [:eolMode |
c945639d2455 #BUGFIX by sr
sr
parents: 1447
diff changeset
   763
            fn := Filename newTemporary.
c945639d2455 #BUGFIX by sr
sr
parents: 1447
diff changeset
   764
            stream := fn writeStream.
c945639d2455 #BUGFIX by sr
sr
parents: 1447
diff changeset
   765
            stream eolMode:eolMode.
1447
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   766
1548
c945639d2455 #BUGFIX by sr
sr
parents: 1447
diff changeset
   767
            [
c945639d2455 #BUGFIX by sr
sr
parents: 1447
diff changeset
   768
                lineEnd := eolModeOfStream value:stream.
1408
9e7cc23513b6 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
   769
1548
c945639d2455 #BUGFIX by sr
sr
parents: 1447
diff changeset
   770
                stream nextPutAll:'line1'; cr.
c945639d2455 #BUGFIX by sr
sr
parents: 1447
diff changeset
   771
                stream nextPutLine:'line2'.
c945639d2455 #BUGFIX by sr
sr
parents: 1447
diff changeset
   772
                stream nextPutAll:'line3
1409
9c3a10712f3d #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1408
diff changeset
   773
line4'; cr.
1548
c945639d2455 #BUGFIX by sr
sr
parents: 1447
diff changeset
   774
                stream close.
1447
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   775
1548
c945639d2455 #BUGFIX by sr
sr
parents: 1447
diff changeset
   776
                contents := fn binaryContentsOfEntireFile.
c945639d2455 #BUGFIX by sr
sr
parents: 1447
diff changeset
   777
                expected := ('line1*line2*line3*line4*' copyReplaceString:'*' withString:lineEnd) asByteArray.
1447
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   778
1548
c945639d2455 #BUGFIX by sr
sr
parents: 1447
diff changeset
   779
                self assert:(contents = expected ).
c945639d2455 #BUGFIX by sr
sr
parents: 1447
diff changeset
   780
            ] ensure:[
c945639d2455 #BUGFIX by sr
sr
parents: 1447
diff changeset
   781
                stream close.
c945639d2455 #BUGFIX by sr
sr
parents: 1447
diff changeset
   782
                fn delete
c945639d2455 #BUGFIX by sr
sr
parents: 1447
diff changeset
   783
            ].
c945639d2455 #BUGFIX by sr
sr
parents: 1447
diff changeset
   784
        ].
1447
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   785
1409
9c3a10712f3d #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1408
diff changeset
   786
    check value:#lf.
9c3a10712f3d #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1408
diff changeset
   787
    check value:#nl.
9c3a10712f3d #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1408
diff changeset
   788
    check value:#crlf.
9c3a10712f3d #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1408
diff changeset
   789
    check value:#cr.
1555
2089b49b4f94 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1548
diff changeset
   790
    check value:#eot.
2089b49b4f94 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1548
diff changeset
   791
    check value:#etx.
1447
2351db93aa5b package changes
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
   792
1407
18f5a9e9c677 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1401
diff changeset
   793
    "
18f5a9e9c677 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1401
diff changeset
   794
     self run:#test40_eolMode
18f5a9e9c677 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1401
diff changeset
   795
     self new test40_eolMode
18f5a9e9c677 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1401
diff changeset
   796
    "
1410
bb99d701dde7 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 1409
diff changeset
   797
1555
2089b49b4f94 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1548
diff changeset
   798
    "Modified: / 06-12-2016 / 14:25:11 / cg"
1897
b5268e1fe140 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1555
diff changeset
   799
!
b5268e1fe140 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1555
diff changeset
   800
b5268e1fe140 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1555
diff changeset
   801
test50_skipThrough
b5268e1fe140 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1555
diff changeset
   802
    |s|
b5268e1fe140 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1555
diff changeset
   803
b5268e1fe140 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1555
diff changeset
   804
         "0123456789012345678901"
2188
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   805
    {     
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   806
        '0123456789012345678901' asArray.
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   807
        '0123456789012345678901' asArray asOrderedCollection.
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   808
        '0123456789012345678901' .
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   809
        '0123456789012345678901' asUnicode16String .
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   810
        '0123456789012345678901' asUnicode32String .
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   811
    } do:[:eachInput |    
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   812
        s := eachInput readStream.
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   813
        self assert:(s position == 0).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   814
        s skipThrough:$0.
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   815
        self assert:(s peek == $1).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   816
        self assert:(s position == 1).
1897
b5268e1fe140 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1555
diff changeset
   817
2188
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   818
        s skipThrough:$0.
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   819
        self assert:(s peek == $1).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   820
        self assert:(s position == 11).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   821
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   822
        s skipThrough:$0.
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   823
        self assert:(s peek == $1).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   824
        self assert:(s position == 21).
1897
b5268e1fe140 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1555
diff changeset
   825
2188
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   826
        s := 'bla { foo }' readStream.
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   827
        s skipThrough:${.
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   828
        self assert:(s peek == $ ).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   829
        s skipThrough:$}.
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   830
        self assert:(s atEnd).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   831
    ].
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   832
    
1897
b5268e1fe140 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1555
diff changeset
   833
    "
b5268e1fe140 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1555
diff changeset
   834
     self run:#test50_skipThrough
b5268e1fe140 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1555
diff changeset
   835
     self new test50_skipThrough
b5268e1fe140 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 1555
diff changeset
   836
    "
2188
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   837
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   838
    "Modified: / 27-03-2019 / 14:50:19 / Claus Gittinger"
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   839
!
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   840
2401
b52413a8eca3 #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2206
diff changeset
   841
test50b_through
b52413a8eca3 #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2206
diff changeset
   842
    |s|
b52413a8eca3 #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2206
diff changeset
   843
b52413a8eca3 #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2206
diff changeset
   844
        "0123456789012345678901"
b52413a8eca3 #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2206
diff changeset
   845
    {   "          1         2 "
b52413a8eca3 #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2206
diff changeset
   846
        '0123456789012345678901' .
b52413a8eca3 #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2206
diff changeset
   847
        '0123456789012345678901' asUnicode16String .
b52413a8eca3 #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2206
diff changeset
   848
        '0123456789012345678901' asUnicode32String .
b52413a8eca3 #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2206
diff changeset
   849
    } do:[:eachInput |
b52413a8eca3 #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2206
diff changeset
   850
        |r|
b52413a8eca3 #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2206
diff changeset
   851
b52413a8eca3 #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2206
diff changeset
   852
        s := eachInput readStream.
b52413a8eca3 #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2206
diff changeset
   853
b52413a8eca3 #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2206
diff changeset
   854
        self assert:(s position == 0).
b52413a8eca3 #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2206
diff changeset
   855
        r := s through:$9.
b52413a8eca3 #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2206
diff changeset
   856
        self assert:(s peek == $0).
b52413a8eca3 #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2206
diff changeset
   857
        self assert:(s position == 10).
b52413a8eca3 #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2206
diff changeset
   858
        self assert:(r = '0123456789').
b52413a8eca3 #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2206
diff changeset
   859
b52413a8eca3 #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2206
diff changeset
   860
        r := s through:$9.
b52413a8eca3 #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2206
diff changeset
   861
        self assert:(s peek == $0).
b52413a8eca3 #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2206
diff changeset
   862
        self assert:(s position == 20).
b52413a8eca3 #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2206
diff changeset
   863
        self assert:(r = '0123456789').
b52413a8eca3 #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2206
diff changeset
   864
b52413a8eca3 #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2206
diff changeset
   865
        r := s through:$9.
b52413a8eca3 #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2206
diff changeset
   866
        self assert:(s peek isNil).
b52413a8eca3 #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2206
diff changeset
   867
        self assert:(s atEnd).
b52413a8eca3 #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2206
diff changeset
   868
        self assert:(r = '01').
b52413a8eca3 #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2206
diff changeset
   869
    ].
b52413a8eca3 #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2206
diff changeset
   870
    
b52413a8eca3 #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2206
diff changeset
   871
    "
b52413a8eca3 #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2206
diff changeset
   872
     self run:#test50b_through
b52413a8eca3 #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2206
diff changeset
   873
     self new test50b_through
b52413a8eca3 #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2206
diff changeset
   874
    "
b52413a8eca3 #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2206
diff changeset
   875
!
b52413a8eca3 #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2206
diff changeset
   876
2188
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   877
test51_skipSeparators
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   878
    |s next|
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   879
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   880
    {   
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   881
        "1234567890123456789"
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   882
        '0   1   2         3' asArray .
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   883
        '0   1   2         3' asArray asOrderedCollection.
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   884
        '0   1   2         3' .
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   885
        '0   1   2         3' asUnicode16String .
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   886
        '0   1   2         3' asUnicode32String .
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   887
    } do:[:eachInput |
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   888
        s := eachInput readStream.
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   889
        next := s skipSeparators.
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   890
        self assert:(s position == 0).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   891
        self assert:(next == $0).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   892
        self assert:(s peek == $0).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   893
        self assert:(s skipSeparators == $0).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   894
        self assert:(s position == 0).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   895
        self assert:(s peek == $0).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   896
        self assert:(s position == 0).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   897
        self assert:(s next == $0).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   898
        self assert:(s position == 1).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   899
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   900
        next := s skipSeparators.
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   901
        self assert:(s position == 4).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   902
        self assert:(next == $1).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   903
        self assert:(s peek == $1).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   904
        self assert:(s skipSeparators == $1).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   905
        self assert:(s position == 4).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   906
        self assert:(s peek == $1).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   907
        self assert:(s position == 4).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   908
        self assert:(s next == $1).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   909
        self assert:(s position == 5).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   910
        
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   911
        next := s skipSeparators.
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   912
        self assert:(s position == 8).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   913
        self assert:(next == $2).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   914
        self assert:(s peek == $2).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   915
        self assert:(s skipSeparators == $2).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   916
        self assert:(s position == 8).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   917
        self assert:(s peek == $2).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   918
        self assert:(s position == 8).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   919
        self assert:(s next == $2).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   920
        self assert:(s position == 9).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   921
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   922
        next := s skipSeparators.
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   923
        self assert:(s position == 18).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   924
        self assert:(next == $3).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   925
        self assert:(s peek == $3).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   926
        self assert:(s skipSeparators == $3).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   927
        self assert:(s position == 18).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   928
        self assert:(s peek == $3).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   929
        self assert:(s position == 18).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   930
        self assert:(s next == $3).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   931
        self assert:(s position == 19).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   932
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   933
        self assert:(s atEnd).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   934
    ].
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   935
    
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   936
    {   
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   937
        "1234567890123456789"
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   938
        '0                  ' asArray.
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   939
        '0                  ' asArray asOrderedCollection.
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   940
        '0                  ' .
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   941
        '0                  ' asUnicode16String .
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   942
        '0                  ' asUnicode32String .
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   943
    } do:[:eachInput |
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   944
        s := eachInput readStream.
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   945
        next := s skipSeparators.
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   946
        self assert:(s position == 0).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   947
        self assert:(next == $0).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   948
        self assert:(s peek == $0).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   949
        self assert:(s skipSeparators == $0).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   950
        self assert:(s position == 0).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   951
        self assert:(s peek == $0).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   952
        self assert:(s position == 0).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   953
        self assert:(s next == $0).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   954
        self assert:(s position == 1).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   955
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   956
        next := s skipSeparators.
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   957
        self assert:(s position == 19).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   958
        self assert:(next isNil).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   959
        self assert:(s peek isNil).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   960
        self assert:(s skipSeparators isNil).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   961
        self assert:(s position == 19).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   962
        self assert:(s peek isNil).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   963
        self assert:(s position == 19).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   964
        self assert:(s next isNil).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   965
        self assert:(s position == 19).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   966
        
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   967
        self assert:(s atEnd).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   968
    ].
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   969
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   970
    {   
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   971
        "12345678901234567890"
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   972
        '0                  x' asArray.
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   973
        '0                  x' asArray asOrderedCollection.
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   974
        '0                  x' .
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   975
        '0                  x' asUnicode16String .
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   976
        '0                  x' asUnicode32String .
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   977
    } do:[:eachInput |
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   978
        s := eachInput readStream.
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   979
        s readLimit:19.
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   980
        
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   981
        next := s skipSeparators.
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   982
        self assert:(s position == 0).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   983
        self assert:(next == $0).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   984
        self assert:(s peek == $0).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   985
        self assert:(s skipSeparators == $0).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   986
        self assert:(s position == 0).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   987
        self assert:(s peek == $0).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   988
        self assert:(s position == 0).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   989
        self assert:(s next == $0).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   990
        self assert:(s position == 1).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   991
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   992
        next := s skipSeparators.
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   993
        self assert:(s position == 19).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   994
        self assert:(next isNil).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   995
        self assert:(s peek isNil).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   996
        self assert:(s skipSeparators isNil).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   997
        self assert:(s position == 19).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   998
        self assert:(s peek isNil).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
   999
        self assert:(s position == 19).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
  1000
        self assert:(s next isNil).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
  1001
        self assert:(s position == 19).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
  1002
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
  1003
        self assert:(s atEnd).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
  1004
    ].
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
  1005
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
  1006
    {   
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
  1007
        "12345678901234567890"
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
  1008
        '0                   ' asArray.
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
  1009
        '0                   ' asArray asOrderedCollection.
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
  1010
        '0                   ' .
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
  1011
        '0                   ' asUnicode16String .
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
  1012
        '0                   ' asUnicode32String .
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
  1013
    } do:[:eachInput |
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
  1014
        s := eachInput readStream.
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
  1015
        s readLimit:19.
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
  1016
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
  1017
        next := s skipSeparators.
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
  1018
        self assert:(s position == 0).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
  1019
        self assert:(next == $0).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
  1020
        self assert:(s peek == $0).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
  1021
        self assert:(s skipSeparators == $0).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
  1022
        self assert:(s position == 0).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
  1023
        self assert:(s peek == $0).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
  1024
        self assert:(s position == 0).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
  1025
        self assert:(s next == $0).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
  1026
        self assert:(s position == 1).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
  1027
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
  1028
        next := s skipSeparators.
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
  1029
        self assert:(s position == 19).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
  1030
        self assert:(next isNil).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
  1031
        self assert:(s peek isNil).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
  1032
        self assert:(s skipSeparators isNil).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
  1033
        self assert:(s position == 19).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
  1034
        self assert:(s peek isNil).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
  1035
        self assert:(s position == 19).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
  1036
        self assert:(s next isNil).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
  1037
        self assert:(s position == 19).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
  1038
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
  1039
        self assert:(s atEnd).
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
  1040
    ].
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
  1041
    "
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
  1042
     self run:#test51_skipSeparators
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
  1043
     self new test51_skipSeparators
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
  1044
    "
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
  1045
11bf104c2bdd #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2165
diff changeset
  1046
    "Created: / 27-03-2019 / 14:44:14 / Claus Gittinger"
2190
df0e2fac468d #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2188
diff changeset
  1047
!
df0e2fac468d #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2188
diff changeset
  1048
df0e2fac468d #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2188
diff changeset
  1049
test52_skipThroughAll
df0e2fac468d #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2188
diff changeset
  1050
    |s|
df0e2fac468d #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2188
diff changeset
  1051
df0e2fac468d #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2188
diff changeset
  1052
        "0123456789012345678901"
df0e2fac468d #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2188
diff changeset
  1053
    {     
df0e2fac468d #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2188
diff changeset
  1054
        '0123456789012345678901' .
df0e2fac468d #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2188
diff changeset
  1055
        '0123456789012345678901' asUnicode16String .
df0e2fac468d #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2188
diff changeset
  1056
        '0123456789012345678901' asUnicode32String .
df0e2fac468d #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2188
diff changeset
  1057
    } do:[:eachInput |    
df0e2fac468d #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2188
diff changeset
  1058
        s := eachInput readStream.
df0e2fac468d #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2188
diff changeset
  1059
        self assert:(s position == 0).
df0e2fac468d #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2188
diff changeset
  1060
        s skipThroughAll:'901'.
df0e2fac468d #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2188
diff changeset
  1061
        self assert:(s peek == $2).
df0e2fac468d #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2188
diff changeset
  1062
        self assert:(s position == 12).
df0e2fac468d #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2188
diff changeset
  1063
df0e2fac468d #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2188
diff changeset
  1064
        s skipThroughAll:'901'.
df0e2fac468d #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2188
diff changeset
  1065
        self assert:(s peek isNil).
df0e2fac468d #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2188
diff changeset
  1066
        self assert:(s atEnd).
df0e2fac468d #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2188
diff changeset
  1067
        self assert:(s position == 22).
df0e2fac468d #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2188
diff changeset
  1068
    ].
df0e2fac468d #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2188
diff changeset
  1069
    
df0e2fac468d #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2188
diff changeset
  1070
        "0123456789012345678901"
df0e2fac468d #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2188
diff changeset
  1071
    {     
df0e2fac468d #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2188
diff changeset
  1072
        '0123456789012345678901' asArray.
df0e2fac468d #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2188
diff changeset
  1073
    } do:[:eachInput |    
df0e2fac468d #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2188
diff changeset
  1074
        s := eachInput readStream.
df0e2fac468d #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2188
diff changeset
  1075
        self assert:(s position == 0).
df0e2fac468d #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2188
diff changeset
  1076
        s skipThroughAll:'901' asArray.
df0e2fac468d #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2188
diff changeset
  1077
        self assert:(s peek == $2).
df0e2fac468d #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2188
diff changeset
  1078
        self assert:(s position == 12).
df0e2fac468d #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2188
diff changeset
  1079
df0e2fac468d #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2188
diff changeset
  1080
        s skipThroughAll:'901' asArray.
df0e2fac468d #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2188
diff changeset
  1081
        self assert:(s peek isNil).
df0e2fac468d #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2188
diff changeset
  1082
        self assert:(s atEnd).
df0e2fac468d #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2188
diff changeset
  1083
        self assert:(s position == 22).
df0e2fac468d #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2188
diff changeset
  1084
    ].
df0e2fac468d #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2188
diff changeset
  1085
df0e2fac468d #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2188
diff changeset
  1086
    s := ReadStream on:'12345678901234567890a'.
df0e2fac468d #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2188
diff changeset
  1087
    s skipThroughAll:'90ab'.
df0e2fac468d #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2188
diff changeset
  1088
    self assert:(s atEnd).
df0e2fac468d #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2188
diff changeset
  1089
    self assert:(s upToEnd = '').  
df0e2fac468d #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2188
diff changeset
  1090
df0e2fac468d #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2188
diff changeset
  1091
    s := ReadStream on:'12345678901234567890'.
df0e2fac468d #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2188
diff changeset
  1092
    s skipThroughAll:'901'.
df0e2fac468d #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2188
diff changeset
  1093
    self assert:(s upToEnd = '234567890').
df0e2fac468d #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2188
diff changeset
  1094
df0e2fac468d #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2188
diff changeset
  1095
    s := ReadStream on:'12345678901234567890'.
df0e2fac468d #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2188
diff changeset
  1096
    s skipThroughAll:'1234'.
df0e2fac468d #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2188
diff changeset
  1097
    self assert:(s upToEnd = '5678901234567890').
df0e2fac468d #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2188
diff changeset
  1098
df0e2fac468d #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2188
diff changeset
  1099
    s := ReadStream on:'12345678901234567890'.
df0e2fac468d #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2188
diff changeset
  1100
    s skipThroughAll:'999'.
df0e2fac468d #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2188
diff changeset
  1101
    self assert:s atEnd.
df0e2fac468d #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2188
diff changeset
  1102
df0e2fac468d #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2188
diff changeset
  1103
    "
df0e2fac468d #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2188
diff changeset
  1104
     self run:#test52_skipThroughAll
df0e2fac468d #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2188
diff changeset
  1105
     self new test52_skipThroughAll
df0e2fac468d #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 2188
diff changeset
  1106
    "
2401
b52413a8eca3 #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2206
diff changeset
  1107
!
b52413a8eca3 #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2206
diff changeset
  1108
b52413a8eca3 #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2206
diff changeset
  1109
test52b_throughAll
b52413a8eca3 #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2206
diff changeset
  1110
    |s|
b52413a8eca3 #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2206
diff changeset
  1111
b52413a8eca3 #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2206
diff changeset
  1112
        "0123456789012345678901"
b52413a8eca3 #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2206
diff changeset
  1113
    {   "          1         2 "
b52413a8eca3 #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2206
diff changeset
  1114
        '0123456789012345678901' .
b52413a8eca3 #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2206
diff changeset
  1115
        '0123456789012345678901' asUnicode16String .
b52413a8eca3 #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2206
diff changeset
  1116
        '0123456789012345678901' asUnicode32String .
b52413a8eca3 #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2206
diff changeset
  1117
    } do:[:eachInput |
b52413a8eca3 #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2206
diff changeset
  1118
        |r|
b52413a8eca3 #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2206
diff changeset
  1119
b52413a8eca3 #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2206
diff changeset
  1120
        s := eachInput readStream.
b52413a8eca3 #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2206
diff changeset
  1121
b52413a8eca3 #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2206
diff changeset
  1122
        self assert:(s position == 0).
b52413a8eca3 #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2206
diff changeset
  1123
        r := s throughAll:'901'.
b52413a8eca3 #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2206
diff changeset
  1124
        self assert:(s peek == $2).
b52413a8eca3 #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2206
diff changeset
  1125
        self assert:(s position == 12).
b52413a8eca3 #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2206
diff changeset
  1126
        self assert:(r = '012345678901').
b52413a8eca3 #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2206
diff changeset
  1127
b52413a8eca3 #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2206
diff changeset
  1128
        r := s throughAll:'901'.
b52413a8eca3 #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2206
diff changeset
  1129
        self assert:(s peek isNil).
b52413a8eca3 #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2206
diff changeset
  1130
        self assert:(s atEnd).
b52413a8eca3 #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2206
diff changeset
  1131
        self assert:(s position == 22).
b52413a8eca3 #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2206
diff changeset
  1132
        self assert:(r = '2345678901').
b52413a8eca3 #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2206
diff changeset
  1133
    ].
b52413a8eca3 #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2206
diff changeset
  1134
    
b52413a8eca3 #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2206
diff changeset
  1135
    "
b52413a8eca3 #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2206
diff changeset
  1136
     self run:#test52b_throughAll
b52413a8eca3 #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2206
diff changeset
  1137
     self new test52b_throughAll
b52413a8eca3 #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2206
diff changeset
  1138
    "
2404
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1139
!
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1140
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1141
test53_upTo
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1142
    {
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1143
        #( (97) (98) (99) (100) (97) (98) (99) (100) (97) (98) (99) (100) )  
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1144
    } do:[:coll |
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1145
        |s e t|
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1146
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1147
        s := coll readStream.
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1148
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1149
        "/ initial state?
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1150
        self assert:(s atEnd not).
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1151
        self assert:(s position == 0).
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1152
        "/ peek returns the correct value
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1153
        e := s peek.
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1154
        self assert:(e = #(97)).
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1155
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1156
        "/ peek should not change any state
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1157
        self assert:(s atEnd not).
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1158
        self assert:(s position == 0).
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1159
        e := s next.
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1160
        self assert:(e = #(97)).
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1161
        self assert:(s position == 1).
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1162
        self assert:(s atEnd not).
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1163
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1164
        e := s peek.
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1165
        self assert:(s position == 1).
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1166
        self assert:(e = #(98)).
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1167
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1168
        s position:0.
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1169
        self assert:(s atEnd not).
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1170
        self assert:(s position == 0).
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1171
        e := s peek.
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1172
        self assert:(e = #(97)).
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1173
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1174
        s position:coll size.
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1175
        self assert:(s atEnd).
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1176
        self assert:(s position == coll size).
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1177
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1178
        s position:0.
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1179
        self assert:(s position == 0).
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1180
        e := s peek.
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1181
        self assert:(e = #(97)).
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1182
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1183
        t := s next:2.
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1184
        self assert:(t size == 2).
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1185
        self assert:(t at:1) = #(97).
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1186
        self assert:(t at:2) = #(98).
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1187
        self assert:(s position == 2).
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1188
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1189
        s position:1.
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1190
        self assert:(s position == 1).
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1191
        e := s peek.
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1192
        self assert:(e = #(98)).
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1193
        t := s upTo:(coll at:1).
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1194
        self assert:(t size == 3).
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1195
        self assert:(t at:1) == (coll at:2).
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1196
        self assert:(t at:2) == (coll at:3).
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1197
        self assert:(t at:3) == (coll at:4).
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1198
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1199
        self assert:(s position == 5).
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1200
        self assert:(s peek = (coll at:2)).
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1201
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1202
        s position:1.
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1203
        (coll at:1) isCharacter ifTrue:[
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1204
            s skipSeparators.
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1205
            self assert:(s position == 1).
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1206
        ].
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1207
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1208
        s position:(coll size - 1).
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1209
        t := s upToEnd.
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1210
        self assert:(s position == coll size).
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1211
        self assert:(t size == 1).
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1212
        self assert:(t at:1) == (coll at:coll size).
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1213
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1214
        s position:0.
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1215
        (coll at:1) isCharacter ifTrue:[
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1216
            t := s nextAlphaNumericWord.
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1217
            self assert:(t asArray = coll asArray).
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1218
            self assert:(s position == coll size).
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1219
        ].
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1220
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1221
    ].
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1222
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1223
    "
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1224
     self run:#test53_upTo
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1225
     self new test53_upTo
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1226
    "
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1227
!
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1228
2405
a39320f70ffa #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2404
diff changeset
  1229
test53b_upToAll
a39320f70ffa #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2404
diff changeset
  1230
    |s t|
a39320f70ffa #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2404
diff changeset
  1231
a39320f70ffa #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2404
diff changeset
  1232
    s := 'abcdefg' readStream.
a39320f70ffa #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2404
diff changeset
  1233
    self assert:( s upToAllExcluding:'de' ) = 'abc'.
a39320f70ffa #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2404
diff changeset
  1234
    self assert:( s upToEnd ) = 'fg'.
a39320f70ffa #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2404
diff changeset
  1235
a39320f70ffa #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2404
diff changeset
  1236
    s := 'abcdefg' readStream.
a39320f70ffa #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2404
diff changeset
  1237
    self assert:( t := s upToAllExcluding:'xx' ) = 'abcdefg'.
a39320f70ffa #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2404
diff changeset
  1238
    self assert:( s atEnd ).
a39320f70ffa #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2404
diff changeset
  1239
    self assert:( s upToEnd ) = ''.
a39320f70ffa #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2404
diff changeset
  1240
2406
1dc618f11b7e #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2405
diff changeset
  1241
    s := 'abcdefg' readStream.
1dc618f11b7e #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2405
diff changeset
  1242
    self assert:( t := s upToAll_positionBefore:'cd' ) = 'ab'.
1dc618f11b7e #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2405
diff changeset
  1243
    self assert:( s upToEnd ) = 'cdefg'.
1dc618f11b7e #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2405
diff changeset
  1244
1dc618f11b7e #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2405
diff changeset
  1245
    s := 'abcdefg' readStream.
1dc618f11b7e #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2405
diff changeset
  1246
    self assert:( t := s upToAll_positionBefore:'xx' ) = 'abcdefg'.
1dc618f11b7e #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2405
diff changeset
  1247
    self assert:( s atEnd ).
1dc618f11b7e #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2405
diff changeset
  1248
    self assert:( s upToEnd ) = ''.
1dc618f11b7e #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2405
diff changeset
  1249
2405
a39320f70ffa #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2404
diff changeset
  1250
    "
a39320f70ffa #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2404
diff changeset
  1251
     self run:#test53b_upToAll
a39320f70ffa #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2404
diff changeset
  1252
     self new test53b_upToAll
a39320f70ffa #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2404
diff changeset
  1253
    "
a39320f70ffa #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2404
diff changeset
  1254
!
a39320f70ffa #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2404
diff changeset
  1255
2406
1dc618f11b7e #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2405
diff changeset
  1256
test54_peek
1dc618f11b7e #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2405
diff changeset
  1257
    |s|
1dc618f11b7e #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2405
diff changeset
  1258
1dc618f11b7e #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2405
diff changeset
  1259
    s := 'abcdefg' readStream.
1dc618f11b7e #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2405
diff changeset
  1260
    self assert:( s peek == $a ).
1dc618f11b7e #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2405
diff changeset
  1261
    self assert:( s peek == $a ).
1dc618f11b7e #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2405
diff changeset
  1262
    self assert:( (s peek:3) = 'abc' ).
1dc618f11b7e #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2405
diff changeset
  1263
    self assert:( s peek == $a ).
1dc618f11b7e #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2405
diff changeset
  1264
    self assert:( s next == $a ).
1dc618f11b7e #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2405
diff changeset
  1265
    self assert:( s upToEnd = 'bcdefg' ).
1dc618f11b7e #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2405
diff changeset
  1266
!
1dc618f11b7e #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2405
diff changeset
  1267
2404
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1268
test60_signalAtEnd
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1269
    |s|
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1270
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1271
    s := 'abc' readStream.
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1272
    s signalAtEnd:true.
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1273
    s next.
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1274
    s next.
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1275
    s next.
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1276
    self should:[s peek] raise:EndOfStreamError.
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1277
    self should:[s next] raise:EndOfStreamError.
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1278
    self should:[s peek] raise:EndOfStreamError.
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1279
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1280
    "
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1281
     self run:#test60_signalAtEnd
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1282
     self new test60_signalAtEnd
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1283
    "
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1284
!
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1285
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1286
test70_nonHomogenousReadWrite
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1287
    |s|
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1288
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1289
    s := #[1 2 3 4 5 6 7 8 9 10 11] readStream.
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1290
    s binary.
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1291
    self assert:(s nextInt16LSB == 16r0201).
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1292
    self assert:(s nextInt16LSB == 16r0403).
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1293
    s reset.
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1294
    self assert:(s nextInt16MSB == 16r0102).
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1295
    self assert:(s nextInt16MSB == 16r0304).
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1296
    s reset.
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1297
    self assert:(s nextInt16Net == 16r0102).
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1298
    self assert:(s nextInt16Net == 16r0304).
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1299
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1300
    s reset.
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1301
    self assert:(s nextInt32LSB == 16r04030201).
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1302
    s reset.
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1303
    self assert:(s nextInt32MSB == 16r01020304).
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1304
    s reset.
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1305
    self assert:(s nextInt32Net == 16r01020304).
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1306
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1307
    s reset.
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1308
    self assert:(s nextInt64LSB == 16r0807060504030201).
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1309
    s reset.
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1310
    self assert:(s nextInt64MSB == 16r0102030405060708).
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1311
    s reset.
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1312
    self assert:(s nextInt64Net == 16r0102030405060708).
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1313
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1314
    "
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1315
     self run:#test70_nonHomogenousReadWrite
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1316
     self new test70_nonHomogenousReadWrite
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1317
    "
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1318
!
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1319
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1320
test71_miscReading
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1321
    |s t|
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1322
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1323
    s := '12345678' readStream.
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1324
    self assert:(s nextDecimalInteger) = 12345678.
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1325
    s reset.
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1326
    self assert:((s nextDecimalInteger:2) = 12).
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1327
    self assert:((s upToEnd) = '345678').
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1328
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1329
    s := '1234 5678' readStream.
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1330
    self assert:(t := s nextDecimalInteger) = 1234.
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1331
    s skipSeparators.
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1332
    self assert:(t := s nextDecimalInteger) = 5678.
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1333
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1334
    s := '12345678' readStream.
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1335
    self assert:(s nextDecimalNumber) = 12345678.
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1336
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1337
    s := '1234 5678' readStream.
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1338
    self assert:(t := s nextDecimalNumber) = 1234.
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1339
    s skipSeparators.
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1340
    self assert:(t := s nextDecimalNumber) = 5678.
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1341
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1342
    s := '12.34 56.78' readStream.
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1343
    self assert:(t := s nextDecimalNumber) = 12.34.
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1344
    s skipSeparators.
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1345
    self assert:(t := s nextDecimalNumber) = 56.78.
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1346
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1347
    "
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1348
     self run:#test71_miscReading
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1349
     self new test71_miscReading
e23a2aec895a #QUALITY by exept
Claus Gittinger <cg@exept.de>
parents: 2401
diff changeset
  1350
    "
636
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1351
! !
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1352
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1353
!StreamTests class methodsFor:'documentation'!
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1354
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1355
version
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1356
    ^ '$Header$'
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1357
!
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1358
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1359
version_CVS
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1360
    ^ '$Header$'
450f6c74861f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1361
! !
952
e9e3c9e81bb1 class: RegressionTests::StreamTests
Stefan Vogel <sv@exept.de>
parents: 676
diff changeset
  1362