Skip to content

Commit

Permalink
chore: add python formatter
Browse files Browse the repository at this point in the history
  • Loading branch information
kasia-kujawa committed Jun 20, 2024
1 parent b6429c2 commit 495443e
Show file tree
Hide file tree
Showing 6 changed files with 75 additions and 33 deletions.
4 changes: 4 additions & 0 deletions .github/workflows/pull_requests.yml
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,10 @@ jobs:
run: sudo apt-get install --yes pylint
- name: Run pylint
run: make pylint
- name: Install black for formatting of Python scripts
run: sudo apt-get install --yes black
- name: Check formatting of Python scripts
run: make black-check

test-bundle-status:
name: Test whether bundle.yaml is up to date
Expand Down
6 changes: 6 additions & 0 deletions Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -238,3 +238,9 @@ pylint:

autopep8:
autopep8 --in-place scripts/*.py

black-check:
black --check scripts/*.py

black-format:
black scripts/*.py
22 changes: 16 additions & 6 deletions scripts/generate_watches.py
Original file line number Diff line number Diff line change
Expand Up @@ -31,16 +31,22 @@ def create_new_file_path(file_path: str, create_new_file: bool) -> str:


def parse_args():
""" Parses command line arguments"""
"""Parses command line arguments"""
parser = argparse.ArgumentParser()
parser.add_argument("--operator-repo-dir",
help="path to directory with Helm Operator repository, e.g. /operator/", default="./")
parser.add_argument(
"--create-new-file", help="determines whether new yaml should be created or the exiting file should be overwritten", default=True)
"--operator-repo-dir",
help="path to directory with Helm Operator repository, e.g. /operator/",
default="./",
)
parser.add_argument(
"--create-new-file",
help="determines whether new yaml should be created or the exiting file should be overwritten",
default=True,
)
return parser.parse_args()


if __name__ == '__main__':
if __name__ == "__main__":
args = parse_args()

image_keys = get_image_keys()
Expand All @@ -54,5 +60,9 @@ def parse_args():
if image_key not in watches[0]["overrideValues"].keys():
overrideValues[image_key] = ""

with open(create_new_file_path(watches_file_path, args.create_new_file), 'w', encoding="utf-8") as nw:
with open(
create_new_file_path(watches_file_path, args.create_new_file),
"w",
encoding="utf-8",
) as nw:
yaml.safe_dump(watches, nw)
17 changes: 11 additions & 6 deletions scripts/get_image_config_keys.py
Original file line number Diff line number Diff line change
Expand Up @@ -19,8 +19,8 @@ def values_to_dictionary(url: str) -> dict:
"""
with urllib.request.urlopen(url) as response:
values = response.read().decode(response.headers.get_content_charset())
values = re.sub(r'(\[\]|\{\})\n(\s+# )', r'\n\2', values, flags=re.M)
values = re.sub(r'^(\s+)# ', r'\1', values, flags=re.M)
values = re.sub(r"(\[\]|\{\})\n(\s+# )", r"\n\2", values, flags=re.M)
values = re.sub(r"^(\s+)# ", r"\1", values, flags=re.M)
return yaml.load(values, Loader=SafeLoader)


Expand All @@ -47,7 +47,7 @@ def extract_keys(dictionary: dict) -> list:
if more_keys is None:
keys.append(key)
else:
keys.extend(f'{key}.{mk}' for mk in more_keys)
keys.extend(f"{key}.{mk}" for mk in more_keys)

return keys

Expand Down Expand Up @@ -75,8 +75,13 @@ def extract_keys(dictionary: dict) -> list:
"metrics-server.image.tag",
]

not_needed_image_keys = ["Percentage", "falco",
"pullPolicy", "pullSecrets", "imagePullSecrets"]
not_needed_image_keys = [
"Percentage",
"falco",
"pullPolicy",
"pullSecrets",
"imagePullSecrets",
]
needed_image_keys = ["image", "tag", "repository"]


Expand Down Expand Up @@ -112,6 +117,6 @@ def get_image_keys() -> list:
return image_keys


if __name__ == '__main__':
if __name__ == "__main__":
image_config_keys = get_image_keys()
print("\n".join(image_config_keys))
57 changes: 37 additions & 20 deletions scripts/update_images.py
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,7 @@ def pairwise(iterable: list) -> list:
element = iter(iterable)
return zip(element, element)


def get_lines(file_path: str) -> list:
"""Read file line by line removing unnecessary string at the beginning,
e.g. output of get_images_sha256.sh:
Expand Down Expand Up @@ -64,8 +65,7 @@ def generate_image_lists(image_list_file: str):
related_images = []
image_envs = []
for image_with_tag, image_with_sha256 in pairwise(lines):
component, _ = image_with_tag.removeprefix(
RED_HAT_REGISTRY).split(":")
component, _ = image_with_tag.removeprefix(RED_HAT_REGISTRY).split(":")
component = component.upper().replace("-", "_")
env_name = f"{ENV_PREFIX}{component}"
related_images.append({"name": env_name, "image": image_with_sha256})
Expand Down Expand Up @@ -124,8 +124,10 @@ def update_envs(envs: list, new_image_envs) -> list:
return not_image_envs + new_image_envs


def update_cluster_service_version(file_path: str, new_related_images: list, new_image_envs: list, create_new_file):
""" Updates components images in bundle/manifests/operator.clusterserviceversion.yaml
def update_cluster_service_version(
file_path: str, new_related_images: list, new_image_envs: list, create_new_file
):
"""Updates components images in bundle/manifests/operator.clusterserviceversion.yaml
Args:
file_path (str): absolute path to bundle/manifests/operator.clusterserviceversion.yaml
Expand All @@ -141,21 +143,24 @@ def update_cluster_service_version(file_path: str, new_related_images: list, new
new_related_images.insert(0, helm_operator_image)
cluster_service_version["spec"]["relatedImages"] = new_related_images

containers = cluster_service_version["spec"]["install"]["spec"][
"deployments"][0]["spec"]["template"]["spec"]["containers"]
containers = cluster_service_version["spec"]["install"]["spec"]["deployments"][
0
]["spec"]["template"]["spec"]["containers"]
# pylint: disable=C0200
for i in range(len(containers)):
name = containers[i]["name"]
if name == "operator":
envs = containers[i]["env"]
containers[i]["env"] = update_envs(envs, new_image_envs)

with open(create_new_file_path(file_path, create_new_file), 'w', encoding="utf-8") as cluster_service_version_file_new:
with open(
create_new_file_path(file_path, create_new_file), "w", encoding="utf-8"
) as cluster_service_version_file_new:
yaml.dump(cluster_service_version, cluster_service_version_file_new)


def update_manager(file_path: str, new_image_envs: list, create_new_file):
""" Updates components images in config/manager/manager.yaml
"""Updates components images in config/manager/manager.yaml
Args:
file_path (str): absolute path to config/manager/manager.yaml
Expand All @@ -171,35 +176,47 @@ def update_manager(file_path: str, new_image_envs: list, create_new_file):
new_contents.append(yaml_content)
else:
envs = yaml_content["spec"]["template"]["spec"]["containers"][0]["env"]
yaml_content["spec"]["template"]["spec"]["containers"][0]["env"] = update_envs(
envs, new_image_envs)
yaml_content["spec"]["template"]["spec"]["containers"][0][
"env"
] = update_envs(envs, new_image_envs)
new_contents.append(yaml_content)

with open(create_new_file_path(file_path, create_new_file), 'w', encoding="utf-8") as manager_file_new:
with open(
create_new_file_path(file_path, create_new_file), "w", encoding="utf-8"
) as manager_file_new:
yaml.safe_dump_all(new_contents, manager_file_new)


def parse_args():
""" Parses command line arguments"""
"""Parses command line arguments"""
parser = argparse.ArgumentParser()
parser.add_argument(
"--images-file", help="file with the list of container images, output of get_images_sha256.sh from sumologic-openshift-images repository", required=True)
parser.add_argument("--operator-repo-dir",
help="path to directory with Helm Operator repository, e.g. /operator/", default="./")
"--images-file",
help="file with the list of container images, output of get_images_sha256.sh from sumologic-openshift-images repository",
required=True,
)
parser.add_argument(
"--operator-repo-dir",
help="path to directory with Helm Operator repository, e.g. /operator/",
default="./",
)
parser.add_argument(
"--create-new-file", help="determines whether new yaml should be created or the exiting file should be overwritten", default=True)
"--create-new-file",
help="determines whether new yaml should be created or the exiting file should be overwritten",
default=True,
)
return parser.parse_args()


if __name__ == '__main__':
if __name__ == "__main__":
args = parse_args()

related_images_list, image_envs_list = generate_image_lists(args.images_file)

csv_path = os.path.join(args.operator_repo_dir,
CLUSTER_SERVICE_VERSION_PATH)
csv_path = os.path.join(args.operator_repo_dir, CLUSTER_SERVICE_VERSION_PATH)
update_cluster_service_version(
csv_path, related_images_list, image_envs_list, args.create_new_file)
csv_path, related_images_list, image_envs_list, args.create_new_file
)

m_path = os.path.join(args.operator_repo_dir, MANAGER_PATH)
update_manager(m_path, image_envs_list, args.create_new_file)
2 changes: 1 addition & 1 deletion vagrant/provision.sh
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,7 @@ add-apt-repository \
"deb [arch=${ARCH}] https://download.docker.com/linux/ubuntu \
$(lsb_release -cs) \
stable"
apt-get install --yes docker-ce docker-ce-cli containerd.io pylint python-is-python3 python3-autopep8 python3-pip
apt-get install --yes docker-ce docker-ce-cli containerd.io pylint python-is-python3 python3-autopep8 python3-pip black
usermod -aG docker vagrant

# Install k8s
Expand Down

0 comments on commit 495443e

Please sign in to comment.