-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathProgramConfiguration.py
110 lines (86 loc) · 3.47 KB
/
ProgramConfiguration.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
#!/usr/bin/env python
# encoding: utf-8
'''
ProgramConfiguration -- Configuration of a target program
Container class that stores various configuration parameters, like platform,
product, OS, version and other parameters relevant for reproducing the issue.
@author: Christian Holler (:decoder)
@license:
This Source Code Form is subject to the terms of the Mozilla Public
License, v. 2.0. If a copy of the MPL was not distributed with this
file, You can obtain one at http://mozilla.org/MPL/2.0/.
@contact: choller@mozilla.com
'''
# Ensure print() compatibility with Python 3
from __future__ import print_function
import sys
import os
from ConfigurationFiles import ConfigurationFiles
class ProgramConfiguration():
def __init__(self, product, platform, os, version=None, env=None, args=None, metadata=None):
'''
@type product: string
@param product: The name of the product/program/branch tested
@type platform: string
@param platform: Platform on which is tested (e.g. x86, x86-64 or arm)
@type os: string
@param os: Operating system on which is tested (e.g. linux, windows, macosx)
'''
self.product = product.lower()
self.platform = platform.lower()
self.os = os.lower()
self.version = version
if env is None:
env = {}
if args is None:
args = []
if metadata is None:
metadata = {}
assert isinstance(env, dict)
assert isinstance(args, list)
assert isinstance(metadata, dict)
self.env = env
self.args = args
self.metadata = metadata
@staticmethod
def fromBinary(binaryPath):
binaryConfig = "%s.fuzzmanagerconf" % binaryPath
if not os.path.exists(binaryConfig):
print("Warning: No binary configuration found at %s" % binaryConfig, file=sys.stderr)
return None
config = ConfigurationFiles([binaryConfig])
mainConfig = config.mainConfig
for field in ["product", "platform", "os"]:
if not field in mainConfig:
raise RuntimeError('Missing "%s" in binary configuration file %s' % (field, binaryConfig))
# Version field is optional
version = None
if "product_version" in mainConfig:
version = mainConfig["product_version"]
return ProgramConfiguration(mainConfig["product"], mainConfig["platform"], mainConfig["os"], version=version, metadata=config.metadataConfig)
def addEnvironmentVariables(self, env):
'''
Add (additional) environment variable definitions. Existing definitions
will be overwritten if they are redefined in the given environment.
@type env: dict
@param env: Dictionary containing the environment variables
'''
assert isinstance(env, dict)
self.env.update(env)
def addProgramArguments(self, args):
'''
Add (additional) program arguments.
@type args: list
@param args: List containing the program arguments
'''
assert isinstance(args, list)
self.args.extend(args)
def addMetadata(self, metadata):
'''
Add (additional) metadata definitions. Existing definitions
will be overwritten if they are redefined in the given metadata.
@type metadata: dict
@param metadata: Dictionary containing the metadata
'''
assert isinstance(metadata, dict)
self.metadata.update(metadata)