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