Skip to content
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

CI/CD - Github Actions #8

Open
simonsan opened this issue Jan 29, 2021 · 2 comments
Open

CI/CD - Github Actions #8

simonsan opened this issue Jan 29, 2021 · 2 comments

Comments

@simonsan
Copy link
Contributor

simonsan commented Jan 29, 2021

Do we want to activate Github Actions in this repository and have some basic CI? For the beginning just to check if it still builds when people PR? In the future maybe even autoupdating mods and uploading them to the Mod workshop after a new update or so?

Usage:

  • Testing (does it build)
  • check code formatting
  • Autoupdating mods + uploading to modworkshop
  • Releasing binary and distribute it via Github Releases
@HSZemi
Copy link
Member

HSZemi commented Jan 29, 2021

I can think of at least three issues with updating mods through GitHub Actions:

  1. You need to have access to the most recent original game asset (dat file)
  2. You need to be able to push new mod versions to the mod centre, so you need to have access to user credentials for that etc.
  3. Mods need to be updated if there is a new dat file or if their specific implementation changes – both cases difficult to catch with a GitHub action I guess

@simonsan
Copy link
Contributor Author

simonsan commented Jan 29, 2021

I can think of at least three issues with updating mods through GitHub Actions:

1. You need to have access to the most recent original game asset (dat file)

Afaik StepS said, that auto-mods is a really valuable resource for people to automatically update their mods. We could ask if that DAT file could be stored somewhere on official servers where we could download it being authenticated. Just as an idea.

2. You need to be able to push new mod versions to the mod centre, so you need to have access to user credentials for that etc.

You can store credentials easily within Github as a Github Secret. I don't think that would be a big problem.

3. Mods need to be updated if there is a new dat file or if their specific implementation changes – both cases difficult to catch with a GitHub action I guess

Implementation changes come with pushes/PRs to master, so that might be not as hard to catch automatically. An action can run on master also by a Cron or whenever there is a PR merged/a commit pushed.

For the new dat file I would probably rely on point 1 or we start having a developer steam account for the SiegeEngineers group where we have a license for AoE2DE and could pull in new versions automatically via CLI. Then we could download that new AoE2DE version once, run our tools against it to extract all the interesting data (for SiegeEngineers/aoc-reference-data, automatic extraction of data for the tech tree etc. pp) and version it for us for the use in our repositories. That would make it possible to have AoE2DE versions somehow being integrated in many automatic workflows.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants