Files
opm-common/python/tests/test_deck.py
Steinar Foss e25416c236 renamed python pkg sunbeam -> opm.
setup.py: test_suite -> tests_suite .

libsunbeam -> libopmcommon_python.

sunbeam -> opm: test_connection ok.

test_deck ok.

test_group_tree ok.

test_grupnet ok.

test_parse_deck.py ok.

test_parse.py ok.

python all tests ok.
2019-08-15 11:02:09 +02:00

74 lines
1.7 KiB
Python

import unittest
import opm.deck
class TestParse(unittest.TestCase):
DECK_STRING = """
START -- 0
10 MAI 2007 /
RUNSPEC
DIMENS
2 2 1 /
GRID
DX
4*0.25 /
DY
4*0.25 /
DZ
4*0.25 /
TOPS
4*0.25 /
REGIONS
OPERNUM
3 3 1 2 /
FIPNUM
1 1 2 3 /
"""
def setUp(self):
self.deck = opm.deck.parse_string(self.DECK_STRING)
def test_deck_in(self):
map(lambda kw: self.assertIn(kw, self.deck), [
'START', 'RUNSPEC', 'DIMENS',
'GRID', 'TOPS', 'REGIONS',
'OPERNUM', 'FIPNUM'
])
map(lambda kw: self.assertNotIn(kw, self.deck), [
'PPCWMAX', 'APIGROUP', 'NOWARN', 'WARN', 'TBLKFAI4', 'WINJMULT'
])
def test_deck_str(self):
self.assertEqual(
'DIMENS 2 2 1 /'.split(),
str(self.deck['DIMENS']).split()
)
self.assertEqual(
'DX 0.25 0.25 0.25 0.25 /'.split(),
str(self.deck['DX']).split()
)
self.assertEqual(
str(opm.deck.parse_string('RUNSPEC\n\nDX\n4*0.5 /')).split(),
'RUNSPEC DX 0.5 0.5 0.5 0.5 /'.split()
)
def test_deck_keyword(self):
for kw in self.deck:
self.assertTrue(len(kw.name) > 0)
for rec in kw:
self.assertTrue( len(rec) > 0 )
for item in rec:
self.assertTrue(len(item) > 0)
def test_deck_FIPNUM(self):
self.assertIn('FIPNUM', self.deck)
self.assertEqual(len(self.deck['FIPNUM']), 1)
self.assertEqual(len(self.deck['FIPNUM'][0]), 1)
self.assertEqual(len(self.deck['FIPNUM'][0][0]), 4)
if __name__ == "__main__":
unittest.main()