mirror of https://github.com/mgba-emu/mgba.git
CInema: Migrate to using ini manifests
This commit is contained in:
parent
0de8f432ec
commit
11b8167708
|
@ -0,0 +1,5 @@
|
||||||
|
[testinfo]
|
||||||
|
fail=1
|
||||||
|
|
||||||
|
[ports.cinema]
|
||||||
|
gb.model=SGB
|
|
@ -1,3 +0,0 @@
|
||||||
config:
|
|
||||||
gb.model: SGB
|
|
||||||
fail: true
|
|
|
@ -0,0 +1,2 @@
|
||||||
|
[testinfo]
|
||||||
|
fail=1
|
|
@ -1 +0,0 @@
|
||||||
fail: true
|
|
|
@ -0,0 +1,2 @@
|
||||||
|
[testinfo]
|
||||||
|
fail=1
|
|
@ -1 +0,0 @@
|
||||||
fail: true
|
|
|
@ -0,0 +1,5 @@
|
||||||
|
[testinfo]
|
||||||
|
fail=1
|
||||||
|
|
||||||
|
[ports.cinema]
|
||||||
|
gb.model=SGB
|
|
@ -1,3 +0,0 @@
|
||||||
config:
|
|
||||||
gb.model: SGB
|
|
||||||
fail: true
|
|
|
@ -0,0 +1,2 @@
|
||||||
|
[ports.cinema]
|
||||||
|
gb.model=SGB
|
|
@ -1,2 +0,0 @@
|
||||||
config:
|
|
||||||
gb.model: SGB
|
|
|
@ -0,0 +1,2 @@
|
||||||
|
[testinfo]
|
||||||
|
fail=1
|
|
@ -1 +0,0 @@
|
||||||
fail: true
|
|
|
@ -0,0 +1,2 @@
|
||||||
|
[testinfo]
|
||||||
|
fail=1
|
|
@ -1 +0,0 @@
|
||||||
fail: true
|
|
|
@ -0,0 +1,2 @@
|
||||||
|
[ports.cinema]
|
||||||
|
gb.model=MGB
|
|
@ -1,2 +0,0 @@
|
||||||
config:
|
|
||||||
gb.model: MGB
|
|
|
@ -0,0 +1,2 @@
|
||||||
|
[ports.cinema]
|
||||||
|
gb.model=SGB
|
|
@ -1,2 +0,0 @@
|
||||||
config:
|
|
||||||
gb.model: SGB
|
|
|
@ -0,0 +1,2 @@
|
||||||
|
[ports.cinema]
|
||||||
|
gb.model=SGB2
|
|
@ -1,2 +0,0 @@
|
||||||
config:
|
|
||||||
gb.model: SGB2
|
|
|
@ -0,0 +1,2 @@
|
||||||
|
[testinfo]
|
||||||
|
fail=1
|
|
@ -1 +0,0 @@
|
||||||
fail: true
|
|
|
@ -0,0 +1,2 @@
|
||||||
|
[testinfo]
|
||||||
|
fail=1
|
|
@ -1 +0,0 @@
|
||||||
fail: true
|
|
|
@ -0,0 +1,2 @@
|
||||||
|
[testinfo]
|
||||||
|
fail=1
|
|
@ -1 +0,0 @@
|
||||||
fail: true
|
|
|
@ -0,0 +1,2 @@
|
||||||
|
[testinfo]
|
||||||
|
fail=1
|
|
@ -1 +0,0 @@
|
||||||
fail: true
|
|
|
@ -0,0 +1,2 @@
|
||||||
|
[testinfo]
|
||||||
|
fail=1
|
|
@ -1 +0,0 @@
|
||||||
fail: true
|
|
|
@ -0,0 +1,2 @@
|
||||||
|
[testinfo]
|
||||||
|
fail=1
|
|
@ -1 +0,0 @@
|
||||||
fail: true
|
|
|
@ -0,0 +1,2 @@
|
||||||
|
[testinfo]
|
||||||
|
fail=1
|
|
@ -1 +0,0 @@
|
||||||
fail: true
|
|
|
@ -0,0 +1,2 @@
|
||||||
|
[testinfo]
|
||||||
|
fail=1
|
|
@ -1 +0,0 @@
|
||||||
fail: true
|
|
|
@ -0,0 +1,2 @@
|
||||||
|
[testinfo]
|
||||||
|
fail=1
|
|
@ -1 +0,0 @@
|
||||||
fail: true
|
|
|
@ -0,0 +1,6 @@
|
||||||
|
[testinfo]
|
||||||
|
skip=60
|
||||||
|
frames=1
|
||||||
|
|
||||||
|
[ports.cinema]
|
||||||
|
sgb.borders=0
|
|
@ -0,0 +1,2 @@
|
||||||
|
[testinfo]
|
||||||
|
fail=1
|
|
@ -1 +0,0 @@
|
||||||
fail: true
|
|
|
@ -0,0 +1,2 @@
|
||||||
|
[testinfo]
|
||||||
|
fail=1
|
|
@ -1 +0,0 @@
|
||||||
fail: true
|
|
|
@ -1,4 +0,0 @@
|
||||||
skip: 60
|
|
||||||
frames: 1
|
|
||||||
config:
|
|
||||||
sgb.borders: false
|
|
|
@ -0,0 +1,2 @@
|
||||||
|
[testinfo]
|
||||||
|
fail=1
|
|
@ -1 +0,0 @@
|
||||||
fail: true
|
|
|
@ -0,0 +1,5 @@
|
||||||
|
[testinfo]
|
||||||
|
fail=1
|
||||||
|
|
||||||
|
[ports.cinema]
|
||||||
|
gb.model=CGB
|
|
@ -1,3 +0,0 @@
|
||||||
config:
|
|
||||||
gb.model: CGB
|
|
||||||
fail: true
|
|
|
@ -0,0 +1,5 @@
|
||||||
|
[testinfo]
|
||||||
|
fail=1
|
||||||
|
|
||||||
|
[ports.cinema]
|
||||||
|
gb.model=AGB
|
|
@ -1,3 +0,0 @@
|
||||||
config:
|
|
||||||
gb.model: AGB
|
|
||||||
fail: true
|
|
|
@ -0,0 +1,2 @@
|
||||||
|
[testinfo]
|
||||||
|
fail=1
|
|
@ -1 +0,0 @@
|
||||||
fail: true
|
|
|
@ -0,0 +1,5 @@
|
||||||
|
[testinfo]
|
||||||
|
fail=1
|
||||||
|
|
||||||
|
[ports.cinema]
|
||||||
|
gb.model=CGB
|
|
@ -1 +0,0 @@
|
||||||
fail: true
|
|
|
@ -0,0 +1,5 @@
|
||||||
|
[testinfo]
|
||||||
|
fail=1
|
||||||
|
|
||||||
|
[ports.cinema]
|
||||||
|
gb.model=CGB
|
|
@ -1,3 +0,0 @@
|
||||||
config:
|
|
||||||
gb.model: CGB
|
|
||||||
fail: true
|
|
|
@ -0,0 +1,2 @@
|
||||||
|
[ports.cinema]
|
||||||
|
gb.model=AGB
|
|
@ -1,2 +0,0 @@
|
||||||
config:
|
|
||||||
gb.model: AGB
|
|
|
@ -0,0 +1,2 @@
|
||||||
|
[ports.cinema]
|
||||||
|
gb.model=CGB
|
|
@ -1,2 +0,0 @@
|
||||||
config:
|
|
||||||
gb.model: CGB
|
|
|
@ -0,0 +1,5 @@
|
||||||
|
[testinfo]
|
||||||
|
fail=1
|
||||||
|
|
||||||
|
[ports.cinema]
|
||||||
|
gb.model=CGB
|
|
@ -1,3 +0,0 @@
|
||||||
config:
|
|
||||||
gb.model: CGB
|
|
||||||
fail: true
|
|
|
@ -6,10 +6,10 @@ import cinema.movie
|
||||||
import itertools
|
import itertools
|
||||||
import glob
|
import glob
|
||||||
import re
|
import re
|
||||||
import yaml
|
|
||||||
from copy import deepcopy
|
from copy import deepcopy
|
||||||
from cinema import VideoFrame
|
from cinema import VideoFrame
|
||||||
from cinema.util import dict_merge
|
from cinema.util import dict_merge
|
||||||
|
from configparser import ConfigParser
|
||||||
|
|
||||||
|
|
||||||
class CinemaTest(object):
|
class CinemaTest(object):
|
||||||
|
@ -22,8 +22,15 @@ class CinemaTest(object):
|
||||||
self.name = '.'.join(path)
|
self.name = '.'.join(path)
|
||||||
self.settings = settings
|
self.settings = settings
|
||||||
try:
|
try:
|
||||||
with open(os.path.join(self.path, 'manifest.yml'), 'r') as f:
|
with open(os.path.join(self.path, 'config.ini'), 'r') as f:
|
||||||
dict_merge(self.settings, yaml.safe_load(f))
|
cfg = ConfigParser()
|
||||||
|
cfg.read_file(f)
|
||||||
|
settings = {}
|
||||||
|
if 'testinfo' in cfg:
|
||||||
|
settings = dict(cfg['testinfo'])
|
||||||
|
if 'ports.cinema' in cfg:
|
||||||
|
settings['config'] = dict(cfg['ports.cinema'])
|
||||||
|
dict_merge(self.settings, settings)
|
||||||
except IOError:
|
except IOError:
|
||||||
pass
|
pass
|
||||||
self.tests = {}
|
self.tests = {}
|
||||||
|
@ -49,9 +56,9 @@ class CinemaTest(object):
|
||||||
def output_settings(self):
|
def output_settings(self):
|
||||||
output_settings = {}
|
output_settings = {}
|
||||||
if 'frames' in self.settings:
|
if 'frames' in self.settings:
|
||||||
output_settings['limit'] = self.settings['frames']
|
output_settings['limit'] = int(self.settings['frames'])
|
||||||
if 'skip' in self.settings:
|
if 'skip' in self.settings:
|
||||||
output_settings['skip'] = self.settings['skip']
|
output_settings['skip'] = int(self.settings['skip'])
|
||||||
return output_settings
|
return output_settings
|
||||||
|
|
||||||
def __lt__(self, other):
|
def __lt__(self, other):
|
||||||
|
|
|
@ -3,7 +3,7 @@ import itertools
|
||||||
import os
|
import os
|
||||||
import os.path
|
import os.path
|
||||||
import pytest
|
import pytest
|
||||||
import yaml
|
from configparser import ConfigParser
|
||||||
|
|
||||||
def pytest_addoption(parser):
|
def pytest_addoption(parser):
|
||||||
parser.addoption("--rebaseline", action="store_true", help="output a new baseline instead of testing")
|
parser.addoption("--rebaseline", action="store_true", help="output a new baseline instead of testing")
|
||||||
|
@ -39,11 +39,12 @@ def pytest_exception_interact(node, call, report):
|
||||||
diffNorm.save(os.path.join(outdir, DIFF_NORM % i))
|
diffNorm.save(os.path.join(outdir, DIFF_NORM % i))
|
||||||
|
|
||||||
if node.config.getoption("--mark-failing"):
|
if node.config.getoption("--mark-failing"):
|
||||||
|
settings = ConfigParser()
|
||||||
try:
|
try:
|
||||||
with open(os.path.join(vtest.path, 'manifest.yml'), 'r') as f:
|
with open(os.path.join(vtest.path, 'config.ini'), 'r') as f:
|
||||||
settings = yaml.safe_load(f)
|
settings.read_file(f)
|
||||||
except IOError:
|
except IOError:
|
||||||
settings = {}
|
pass
|
||||||
settings['fail'] = True
|
settings.set('testinfo', 'fail', '1')
|
||||||
with open(os.path.join(vtest.path, 'manifest.yml'), 'w') as f:
|
with open(os.path.join(vtest.path, 'config.ini'), 'w') as f:
|
||||||
yaml.dump(settings, f, default_flow_style=False)
|
settings.write(f)
|
||||||
|
|
|
@ -23,7 +23,7 @@ setup(
|
||||||
packages=["mgba"],
|
packages=["mgba"],
|
||||||
setup_requires=['cffi>=1.6', 'pytest-runner'],
|
setup_requires=['cffi>=1.6', 'pytest-runner'],
|
||||||
install_requires=['cffi>=1.6', 'cached-property'],
|
install_requires=['cffi>=1.6', 'cached-property'],
|
||||||
extras_require={'pil': ['Pillow>=2.3'], 'cinema': ['pyyaml', 'pytest']},
|
extras_require={'pil': ['Pillow>=2.3'], 'cinema': ['pytest']},
|
||||||
tests_require=['pytest'],
|
tests_require=['pytest'],
|
||||||
cffi_modules=["_builder.py:ffi"],
|
cffi_modules=["_builder.py:ffi"],
|
||||||
license="MPL 2.0",
|
license="MPL 2.0",
|
||||||
|
|
|
@ -24,7 +24,7 @@ def pytest_generate_tests(metafunc):
|
||||||
for test in testList:
|
for test in testList:
|
||||||
marks = []
|
marks = []
|
||||||
xfail = test.settings.get('fail')
|
xfail = test.settings.get('fail')
|
||||||
if xfail:
|
if xfail and bool(xfail):
|
||||||
marks = pytest.mark.xfail(reason=xfail if isinstance(xfail, str) else None)
|
marks = pytest.mark.xfail(reason=xfail if isinstance(xfail, str) else None)
|
||||||
params.append(pytest.param(test, id=test.name, marks=marks))
|
params.append(pytest.param(test, id=test.name, marks=marks))
|
||||||
metafunc.parametrize('vtest', params, indirect=True)
|
metafunc.parametrize('vtest', params, indirect=True)
|
||||||
|
|
Loading…
Reference in New Issue