-
Notifications
You must be signed in to change notification settings - Fork 3
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Support Platform CLI #763
Support Platform CLI #763
Conversation
…riginal intention I believe)
79fe466
to
38922e1
Compare
38922e1
to
b6f626e
Compare
* main: Update obsolete GitHub Actions (#774)
@doshitan I see you merged main into this branch, but I was wondering if that's necessary. template-only-cd is supposed to do that automatically now, is that step not working as intended? |
There was a conflict on the auto merge: https://github.com/navapbc/template-infra/actions/runs/11705178511/job/32599329386 |
0125619
to
25904e1
Compare
9390f2f
to
7d9f03b
Compare
7d9f03b
to
7fb0495
Compare
Application templates can provide overrides in their own directories, with the scanning falling back to the top-level project configs otherwise.
Should be prefixed with `infra/`
@@ -10,11 +10,11 @@ Each app should have: | |||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This change seems to be breaking NavaLabs DST repository CI @doshitan would you have any recommendations to make sure our CI lint markdown check is passing?
Ref: https://github.com/navapbc/labs-decision-support-tool/actions/runs/12776615414/job/35615909285
Ticket
Resolves #691
Resolves #557
Resolves #478
Resolves #569
Resolves #647
Changes
A new tool, the Platform CLI[1], has been developed to replace the existing install/update scripts. It currently utilizes the copier[2] library to drive most of the logic. Copier by design really prefers one-repo = one-template, which is not quite how we have
template-infra
setup. So the Platform CLI has special logic to treat this repo as effectively two different templates, "base" and "app":{{app_name}}
in the file pathTo support this new tool, a variety of changes are necessary, notable ones being:
copier.yml
config file which holds the questions for templating, with only questions relevant to "base" or "app" templates being asked and saved during the relevant install/update phasesproject-config
is now configuration on the "base" templateapp_has_dev_env_setup
answer, rather than manually finding and un-commenting bits of code.template-infra/
folder to hold the answers files that copier generates in projects{{app_name}}
.github/workflows/ci-infra-service.yml
(and associatedinfra/test/infra_test.go
) to become parameterized/setup per-app (inci-{{app_name}}-infra-service.yml.jinja
)infra/test/infra_test.go
/health
endpoint instead of/
for check since all apps are required to have a health endpoint but not required to respond to a root requestenable_https
.infra/app
to now referenceinfra/<APP_NAME>
(and normalize most of the docs to use<APP_NAME>
as the placeholder for this, instead of the mix of things we were using before)app/
totemplate-only-app/
. Places wanting to use it as their example app for testing can copytemplate-only-app/
to the appropriate app-named directory..github/workflows/template-only-ci-infra.yml
to use the Platform CLI to install the template with example app and run tests against that. Necessitates thetemplate_infra_test.go
changes.infra/networks/main.tf.jinja
with the installed apps[1] https://github.com/navapbc/platform-cli
[2] https://copier.readthedocs.io/en/stable/
Context for reviewers
TODO:
base_<foo>
? Then the CLI tool could read the base answers and auto populate them for "app" stuff? Ideally we'd separate the base and app infra templates to make this cleaner, but in the interim maybe do that? Move "app" questions to anapp_
prefix?app/
. Maybeexample-app/
ortemplate-only-app/
.github/workflows/README.md
,docs/infra/pull-request-environments.md
) to point to blob/main before mergeTheFixed by removing feature flags/Evidently from the template onTemplate CI Infra Checks / Infra Tests
CI failures are due to #781, the CI was passing before the AWS changes.main
.Testing
This repo's CD has been updated to use the Platform CLI tool and this branch: https://github.com/navapbc/template-infra/blob/main/.github/workflows/template-only-cd.yml
WIP on gettingpfml-starter-kit-app
using the Platform CLI tool and this branch: https://github.com/navapbc/pfml-starter-kit-app/pull/223And the cleaner
pfml-starter-kit-app
upgrade PR: https://github.com/navapbc/pfml-starter-kit-app/pull/225Vuln scan GH Action refactor testing: https://github.com/navapbc/platform-test/actions/runs/12584792796/job/35075171716?pr=147