Skip to content

Commit

Permalink
ci: Check that setup manifests are complete (#158)
Browse files Browse the repository at this point in the history
  • Loading branch information
ThiefMaster authored Mar 23, 2024
1 parent a5faf14 commit 6cf2837
Show file tree
Hide file tree
Showing 2 changed files with 56 additions and 0 deletions.
52 changes: 52 additions & 0 deletions .github/utils/check_manifests.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,52 @@
# This file is part of the CERN Indico plugins.
# Copyright (C) 2014 - 2024 CERN
#
# The CERN Indico plugins are free software; you can redistribute
# them and/or modify them under the terms of the MIT License; see
# the LICENSE file for more details.

import sys
from pathlib import Path


def _validate_manifest(plugin_dir: Path):
pkg_dir = plugin_dir / f'indico_{plugin_dir.name}'
pkg_file = plugin_dir / f'indico_{plugin_dir.name}.py'
if not pkg_dir.exists() and pkg_file.exists():
return True
data_dirs = [
sub.name
for sub in pkg_dir.iterdir()
if sub.name not in {'__pycache__', 'client'} and sub.is_dir() and not any(sub.glob('*.py'))
]
if not data_dirs:
return True
expected_manifest = {f'graft {pkg_dir.name}/{plugin_dir}' for plugin_dir in data_dirs}
manifest_file = plugin_dir / 'MANIFEST.in'
if not manifest_file.exists():
print(f'::error::{plugin_dir.name} has no manifest')
for line in expected_manifest:
print(f'::error::manifest entry missing: {line}')
return False
manifest_lines = set(manifest_file.read_text().splitlines())
if missing := (expected_manifest - manifest_lines):
print(f'::error::{plugin_dir.name} has incomplete manifest')
for line in missing:
print(f'::error::manifest entry missing: {line}')
return False
return True


def main():
errors = False
for plugin_dir in Path().iterdir():
if not plugin_dir.is_dir() or plugin_dir.name == '_meta' or not (plugin_dir / 'setup.cfg').exists():
continue
if not _validate_manifest(plugin_dir):
errors = True

return 1 if errors else 0


if __name__ == '__main__':
sys.exit(main())
4 changes: 4 additions & 0 deletions .github/workflows/ci.yml
Original file line number Diff line number Diff line change
Expand Up @@ -126,7 +126,11 @@ jobs:
echo "VIRTUAL_ENV=$(pwd)/.venv" >> $GITHUB_ENV
echo "$(pwd)/.venv/bin" >> $GITHUB_PATH
- name: Check manifests
run: python .github/utils/check_manifests.py

- name: Check import sorting
if: success() || failure()
run: isort --diff --check-only .

- name: Check headers
Expand Down

0 comments on commit 6cf2837

Please sign in to comment.