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 runners #169

Merged
merged 63 commits into from
Jun 18, 2024
Merged

Ci runners #169

merged 63 commits into from
Jun 18, 2024

Conversation

dguittet
Copy link
Collaborator

@dguittet dguittet commented May 21, 2024

  1. Github actions now have all 4 platforms
  2. Tests now include DView and wexsandbox
  3. Use wxWidgets binary artifact from LK CI instead of building it
  4. Update cache of LK and SSC to the matching branch

@dguittet dguittet requested review from brtietz and sjanzou May 21, 2024 22:15
Copy link
Collaborator

@sjanzou sjanzou left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

All tests are passing - great job!

It would be nice to move to wxWidgets 3.2.4 to be consistent with our current build process and public releases.

Is the change to 3.2.4 easily available for updating as wxWidgets changes?

I see "latest" and "3.2.3" used in the scripts - will the upgrade be as simple as changing to 3.2.4?

.github/workflows/ci.yml Outdated Show resolved Hide resolved
Copy link
Collaborator

@brtietz brtietz left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Great job with the caching!

It looks like there are a few places where the develop branches of other repos are references, whereas this is being merged into patch. Is there a reason for the mismatch?

echo "RAPIDJSONDIR=$GITHUB_WORKSPACE/ssc" >>$GITHUB_ENV
- name: Get git ref of sibling dependency SSC
run: |
ref=$(git ls-remote --exit-code git://github.com/NREL/ssc.git refs/heads/patch | awk '{print $1}')
ref=$(git ls-remote --exit-code https://github.com/NREL/ssc.git refs/heads/develop | awk '{print $1}')
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This looks like there will be a branch mismatch between patch and develop. Should this be patch?

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

How is this "base" branch handled? Are there different ci.yml for each branch?

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

For events triggered by pull_request, then you have the pull request merge branch, but for the standalone push, how should the default branch be determined as develop or patch?

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

That's not intentional: NREL/SAM#1664 I'm not sure how that got reverted but it should be patch.

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

For events triggered by pull_request, then you have the pull request merge branch, but for the standalone push, how should the default branch be determined as develop or patch?

Branches from patch should have patch as the default in the CI script, whereas branches from develop should have develop.

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

For events triggered by pull_request, then you have the pull request merge branch, but for the standalone push, how should the default branch be determined as develop or patch?

Branches from patch should have patch as the default in the CI script, whereas branches from develop should have develop.

Yes, that is clear. My question was mechanistic. I may just have two versions of ci.yml on each branch.

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Most years, a commit when we switch from patch to develop (and vice versa) has been sufficient, but as we see right now it's error prone. How would two ci.yml instances work?

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This might be a bad idea but I was thinking we'd have a different version of ci.yml on each branch. I think then the first time we merge patch into develop, we have to manually unselect the changes in ci.yml. But then after that, that difference won't be a tracked diff, and shouldn't show up. I'm not 100% sure it'll work but I could try.

There kind of is a way to get the "closest parent branch" but it uses a lot of bash magic (that I don't understand) and might be unreliable.

.github/workflows/ci.yml Outdated Show resolved Hide resolved
.github/workflows/ci.yml Outdated Show resolved Hide resolved
.github/workflows/ci.yml Outdated Show resolved Hide resolved
@dguittet dguittet merged commit 9362430 into patch Jun 18, 2024
8 checks passed
@dguittet dguittet deleted the ci_runners branch June 18, 2024 23:10
dguittet added a commit that referenced this pull request Jul 30, 2024
* Ci runners (#169)

* Merge in patch branch and re-target develop

* add windows build

* windows ci

* windows

* windows

* fix paths

* windows lk

* debug

* check python

* python version

* try downloading wx

* update linux

* linux

* fix syntax

* download wx

* add secrets

* tokens

* download_wx

* download_wx

* token

* msg

* fix

* cache build off

* windows

* add mac build

* fix dirs

* fix mac

* pip on mac

* pip

* mac

* fix git ls-remote

* fix mac

* mac

* update all

* windows secrets

* fix paths

* add error message

* build lk always

* fix paths

* fix paths

* fix paths

* windows

* move windows download

* clean up and fix artifacts

* use caches

* windows cache

* fix caching

* fix paths for artifacts

* fix caching path

* fix caching

* get branch name

* cleanup

* fix ssc cache

* fix windows

* use caching for wx 3.2.4

* release mode

* release ver

* fix windows path

* remove download_wx.py

* add default branch

* debug vs rel for MSVC

* select branch based on push or pull_request

---------

Co-authored-by: Brian Mirletz <brian.mirletz@nrel.gov>

* shell

* fix

* fix windows

* windows

---------

Co-authored-by: Brian Mirletz <brian.mirletz@nrel.gov>
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

Successfully merging this pull request may close these issues.

3 participants