Files
opm-common/python/tests/parse.py

74 lines
1.8 KiB
Python
Raw Normal View History

import unittest
import sunbeam
2017-05-16 12:32:23 +02:00
import os.path
class TestParse(unittest.TestCase):
2017-01-12 09:43:03 +01:00
REGIONDATA = """
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.spe3fn = 'spe3/SPE3CASE1.DATA'
2017-05-16 12:32:23 +02:00
self.norne_fname = os.path.abspath('../../examples/data/norne/NORNE_ATW2013.DATA')
def test_parse(self):
spe3 = sunbeam.parse(self.spe3fn)
self.assertEqual('SPE 3 - CASE 1', spe3.state.title)
2016-11-25 16:33:45 +01:00
def test_parse_with_recovery(self):
recovery = [("PARSE_RANDOM_SLASH", sunbeam.action.ignore)]
spe3 = sunbeam.parse(self.spe3fn, recovery=recovery)
2016-11-25 16:33:45 +01:00
def test_parse_with_multiple_recoveries(self):
recoveries = [ ("PARSE_RANDOM_SLASH", sunbeam.action.ignore),
("FOO", sunbeam.action.warn),
("PARSE_RANDOM_TEXT", sunbeam.action.throw) ]
2016-11-25 16:33:45 +01:00
spe3 = sunbeam.parse(self.spe3fn, recovery=recoveries)
2016-11-25 16:33:45 +01:00
def test_throw_on_invalid_recovery(self):
recoveries = [ ("PARSE_RANDOM_SLASH", 3.14 ) ]
2016-11-25 16:33:45 +01:00
with self.assertRaises(TypeError):
sunbeam.parse(self.spe3fn, recovery=recoveries)
2016-11-25 16:33:45 +01:00
with self.assertRaises(TypeError):
sunbeam.parse(self.spe3fn, recovery="PARSE_RANDOM_SLASH")
2017-01-12 09:43:03 +01:00
def test_data(self):
pass
#regtest = sunbeam.parse(self.REGIONDATA)
#self.assertEqual([3,3,1,2], regtest.props()['OPERNUM'])
2017-05-16 12:32:23 +02:00
def test_parse_norne(self):
state = sunbeam.parse(self.norne_fname, recovery=[('PARSE_RANDOM_SLASH', sunbeam.action.ignore)])
es = state.state
2017-05-16 12:32:23 +02:00
self.assertEqual(46, es.grid().getNX())
self.assertEqual(112, es.grid().getNY())
self.assertEqual(22, es.grid().getNZ())
if __name__ == "__main__":
unittest.main()