url: str
-class Channel(types.SimpleNamespace):
+class SearchPath(types.SimpleNamespace):
+ release_name: str
+
+
+class Channel(SearchPath):
alias_of: str
channel_html: bytes
channel_url: str
git_repo: str
git_revision: str
old_git_revision: str
- release_name: str
table: Dict[str, ChannelTableEntry]
request = urllib.request.urlopen(channel.channel_url, timeout=10)
channel.channel_html = request.read()
channel.forwarded_url = request.geturl()
- v.result(request.status == 200)
+ v.result(request.status == 200) # type: ignore # (for old mypy)
v.check('Got forwarded', channel.channel_url != channel.forwarded_url)
v.status("Verifying file digest")
file_digest = digest_file(path)
v.result(file_digest == digest)
- return path
+ return path # type: ignore # (for old mypy)
def fetch_resources(v: Verification, channel: Channel) -> None:
os.makedirs(os.path.dirname(cache_file), exist_ok=True)
open(cache_file, 'w').write(store_tarball)
- return store_tarball
+ return store_tarball # type: ignore # (for old mypy)
def check_channel_metadata(
'-n1',
'--format=%ct-%h',
'--abbrev=11',
+ '--no-show-signature',
channel.git_revision],
stdout=subprocess.PIPE)
v.result(process.returncode == 0 and process.stdout != b'')
process.stdout.decode().strip())
+def read_search_path(conf: configparser.SectionProxy) -> Channel:
+ return Channel(**dict(conf.items()))
+
+
def read_config(filename: str) -> configparser.ConfigParser:
config = configparser.ConfigParser()
config.read_file(open(filename), filename)
if args.channels and section not in args.channels:
continue
- channel = Channel(**dict(config[section].items()))
+ channel = read_search_path(config[section])
if hasattr(channel, 'alias_of'):
assert not hasattr(channel, 'git_repo')
v, conf['tarball_url'], Digest16(
conf['tarball_sha256']))
- channel = Channel(**dict(conf.items()))
+ channel = read_search_path(conf)
ensure_git_rev_available(v, channel)
return git_get_tarball(v, channel)
args.func(args)
-main()
+if __name__ == '__main__':
+ main()