2017-12-28 23:01:17 +01:00
|
|
|
from ..check import Check
|
|
|
|
import re
|
|
|
|
|
|
|
|
class CheckEsid(Check):
|
|
|
|
'''Ensure tests specify only valid `es6id's'''
|
|
|
|
ID = 'ESID'
|
|
|
|
|
|
|
|
def __init__(self):
|
|
|
|
#self.es5idRegex = re.compile(r"^S?(B|\d+)(\.\d+)+(-(\d+|[a-z]|i+))*(_A\d(\.\d+)?(_T\d(\.\d+)?)?)?$")
|
|
|
|
self.es6idRegex = re.compile(r"^(S?(B|\d+)(\.\d+)+(((_A\d\.\d)?_T?\d)|[ _]S\d+(\.[a-z])*)?(, |$))+")
|
2018-01-10 23:32:37 +01:00
|
|
|
self.esidRegex = re.compile(r"^(pending|(prod|sec|sup)-[-_A-Za-z0-9.%@]+)$")
|
2017-12-28 23:01:17 +01:00
|
|
|
|
|
|
|
def run(self, name, meta, source):
|
|
|
|
if not meta:
|
|
|
|
return
|
|
|
|
|
2018-01-10 23:22:45 +01:00
|
|
|
if 'es6id' not in meta and 'esid' not in meta:
|
|
|
|
return
|
|
|
|
|
2017-12-28 23:01:17 +01:00
|
|
|
# es5ids are a mess
|
|
|
|
#if 'es5id' in meta:
|
|
|
|
# es5id = str(meta['es5id'])
|
|
|
|
# if self.es5idRegex.match(es5id) == None:
|
|
|
|
# return 'The `es5id` tag has the wrong format: %s' % es5id
|
|
|
|
|
|
|
|
if 'es6id' in meta:
|
2018-01-10 23:22:45 +01:00
|
|
|
es6id = str(meta['es6id'])
|
|
|
|
if self.es6idRegex.match(es6id) == None:
|
|
|
|
return 'The `es6id` tag has the wrong format: %s' % es6id
|
2017-12-28 23:01:17 +01:00
|
|
|
|
|
|
|
if 'esid' in meta:
|
2018-01-10 23:22:45 +01:00
|
|
|
esid = str(meta['esid'])
|
|
|
|
if self.esidRegex.match(esid) == None:
|
|
|
|
return 'The `esid` tag has the wrong format: %s' % esid
|
|
|
|
|
|
|
|
|