Initial commit of OpenSPARC T2 architecture model.
[OpenSPARC-T2-SAM] / sam-t2 / devtools / v9 / lib / python2.4 / test / test_univnewlines.py
CommitLineData
920dae64
AT
1# Tests universal newline support for both reading and parsing files.
2import unittest
3import os
4import sys
5from test import test_support
6
7if not hasattr(sys.stdin, 'newlines'):
8 raise test_support.TestSkipped, \
9 "This Python does not have universal newline support"
10
11FATX = 'x' * (2**14)
12
13DATA_TEMPLATE = [
14 "line1=1",
15 "line2='this is a very long line designed to go past the magic " +
16 "hundred character limit that is inside fileobject.c and which " +
17 "is meant to speed up the common case, but we also want to test " +
18 "the uncommon case, naturally.'",
19 "def line3():pass",
20 "line4 = '%s'" % FATX,
21 ]
22
23DATA_LF = "\n".join(DATA_TEMPLATE) + "\n"
24DATA_CR = "\r".join(DATA_TEMPLATE) + "\r"
25DATA_CRLF = "\r\n".join(DATA_TEMPLATE) + "\r\n"
26
27# Note that DATA_MIXED also tests the ability to recognize a lone \r
28# before end-of-file.
29DATA_MIXED = "\n".join(DATA_TEMPLATE) + "\r"
30DATA_SPLIT = [x + "\n" for x in DATA_TEMPLATE]
31del x
32
33class TestGenericUnivNewlines(unittest.TestCase):
34 # use a class variable DATA to define the data to write to the file
35 # and a class variable NEWLINE to set the expected newlines value
36 READMODE = 'U'
37 WRITEMODE = 'wb'
38
39 def setUp(self):
40 fp = open(test_support.TESTFN, self.WRITEMODE)
41 fp.write(self.DATA)
42 fp.close()
43
44 def tearDown(self):
45 try:
46 os.unlink(test_support.TESTFN)
47 except:
48 pass
49
50 def test_read(self):
51 fp = open(test_support.TESTFN, self.READMODE)
52 data = fp.read()
53 self.assertEqual(data, DATA_LF)
54 self.assertEqual(repr(fp.newlines), repr(self.NEWLINE))
55
56 def test_readlines(self):
57 fp = open(test_support.TESTFN, self.READMODE)
58 data = fp.readlines()
59 self.assertEqual(data, DATA_SPLIT)
60 self.assertEqual(repr(fp.newlines), repr(self.NEWLINE))
61
62 def test_readline(self):
63 fp = open(test_support.TESTFN, self.READMODE)
64 data = []
65 d = fp.readline()
66 while d:
67 data.append(d)
68 d = fp.readline()
69 self.assertEqual(data, DATA_SPLIT)
70 self.assertEqual(repr(fp.newlines), repr(self.NEWLINE))
71
72 def test_seek(self):
73 fp = open(test_support.TESTFN, self.READMODE)
74 fp.readline()
75 pos = fp.tell()
76 data = fp.readlines()
77 self.assertEqual(data, DATA_SPLIT[1:])
78 fp.seek(pos)
79 data = fp.readlines()
80 self.assertEqual(data, DATA_SPLIT[1:])
81
82 def test_execfile(self):
83 namespace = {}
84 execfile(test_support.TESTFN, namespace)
85 func = namespace['line3']
86 self.assertEqual(func.func_code.co_firstlineno, 3)
87 self.assertEqual(namespace['line4'], FATX)
88
89
90class TestNativeNewlines(TestGenericUnivNewlines):
91 NEWLINE = None
92 DATA = DATA_LF
93 READMODE = 'r'
94 WRITEMODE = 'w'
95
96class TestCRNewlines(TestGenericUnivNewlines):
97 NEWLINE = '\r'
98 DATA = DATA_CR
99
100class TestLFNewlines(TestGenericUnivNewlines):
101 NEWLINE = '\n'
102 DATA = DATA_LF
103
104class TestCRLFNewlines(TestGenericUnivNewlines):
105 NEWLINE = '\r\n'
106 DATA = DATA_CRLF
107
108class TestMixedNewlines(TestGenericUnivNewlines):
109 NEWLINE = ('\r', '\n')
110 DATA = DATA_MIXED
111
112
113def test_main():
114 test_support.run_unittest(
115 TestNativeNewlines,
116 TestCRNewlines,
117 TestLFNewlines,
118 TestCRLFNewlines,
119 TestMixedNewlines
120 )
121
122if __name__ == '__main__':
123 test_main()