#build-harness (2023-04)
Help with the Cloud Posse build-harness https://github.com/cloudposse/build-harness
2023-04-03
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
unsure if this is the right place, but I’m seeing this locally and on github actions randomly.
Cloning <https://github.com/cloudposse/build-harness.git#master>...
Cloning into 'build-harness'...
make[1]: Entering directory '/home/runner/work/infrastructure/infrastructure'
.build-harness:1: *** missing separator. Stop.
data:image/s3,"s3://crabby-images/cb438/cb438d5ba5c2af102737ccb6cbd16763b442a41f" alt="David Schmidt avatar"
We often see this sort of failure when it’s really a failure to bootstrap - which in turn is often either rate-limiting, or not supplying good creds to not get rate-limited.
unsure if this is the right place, but I’m seeing this locally and on github actions randomly.
Cloning <https://github.com/cloudposse/build-harness.git#master>...
Cloning into 'build-harness'...
make[1]: Entering directory '/home/runner/work/infrastructure/infrastructure'
.build-harness:1: *** missing separator. Stop.
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
it could be rate limiting since it is random
data:image/s3,"s3://crabby-images/cb438/cb438d5ba5c2af102737ccb6cbd16763b442a41f" alt="David Schmidt avatar"
We always supply user creds so we get the benefit of our subscription rather than hoping it goes through
data:image/s3,"s3://crabby-images/cb438/cb438d5ba5c2af102737ccb6cbd16763b442a41f" alt="David Schmidt avatar"
A typical Makefile that bootstraps starts like this (we use -extensions extensively) :
# Bootstrap (pull) the build harness
# GITHUB_USER containing '@' char must be escaped with '%40'
GITHUB_USER := $(shell echo $(GITHUB_USER) | sed 's/@/%40/g')
GITHUB_TOKEN ?=
BUILD_HARNESS_EXTENSIONS_BRANCH=master
-include $(shell [ -f ".build-harness-bootstrap" ] || curl -sL -o .build-harness-bootstrap -H "Authorization: token $(GITHUB_TOKEN)" -H "Accept: application/vnd.github.v3.raw" "<https://raw.github.com/open-cluster-management/build-harness-extensions/master/templates/Makefile.build-harness-bootstrap>"; echo .build-harness-bootstrap)
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Interesting…. @Jeremy G (Cloud Posse), should we consider adding something like @David Schmidt’s answer?
data:image/s3,"s3://crabby-images/f32e8/f32e85f027666416b654b0749258dcbce33cf974" alt="Jeremy G (Cloud Posse) avatar"
@johncblandii There was some breakage to build-harness overnight, because build-harness pulls in packages which has had a few bugs introduced as we enhanced it to support packaging for arm64
, but nothing that I saw like “missing separator”. There were also 2 GitHub incidents that might have contributed to the error:
- Incident with Git Operations
- Incident with Actions and Pages
So I expect this was a transient error, but if it happens again, please see if you can track down where the missing separator actually is.
@Erik Osterman (Cloud Posse) We curl
the bootstrap file from <https://raw.githubusercontent.com>
which
- Has a generous rate limit of 5000 request per IP address per hour
- Does not accept authentication and therefore does not benefit from it
After that, we use
git clone
to download the repo, which automatically uses whatever user credentials are available. @David Schmidt Have you hit rate limits on[raw.githubusercontent.com](http://raw.githubusercontent.com)
?
GitHub’s Status Page - Incident with Git Operations.
GitHub’s Status Page - Incident with Actions and Pages.
data:image/s3,"s3://crabby-images/cb438/cb438d5ba5c2af102737ccb6cbd16763b442a41f" alt="David Schmidt avatar"
We only pull build harness / build harness extensions with our own orgs, so I can’t speak to that.
data:image/s3,"s3://crabby-images/cb438/cb438d5ba5c2af102737ccb6cbd16763b442a41f" alt="David Schmidt avatar"
So if, for example, anyone else forks and uses them locally (in their own org), they will hit this problem if they use build harness with any regularity.
data:image/s3,"s3://crabby-images/f32e8/f32e85f027666416b654b0749258dcbce33cf974" alt="Jeremy G (Cloud Posse) avatar"
@Jeremy G (Cloud Posse) has joined the channel
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
did something change with make packages/install/terraform-docs
?
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
yeah, something is off.
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
oh…logs tell me directly:
Package terraform-docs no longer supported. Skipping
data:image/s3,"s3://crabby-images/f32e8/f32e85f027666416b654b0749258dcbce33cf974" alt="Jeremy G (Cloud Posse) avatar"
@johncblandii Where did you see this error? terraform-docs
is still supported by Cloud Posse, now on both amd64
and arm64
.
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
in our gha run
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
let me add it back. 1 sec
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
- name: Install terraform-docs
shell: bash
env:
INSTALL_PATH: "${{ github.workspace }}/bin"
run: |
make init
mkdir -p "${INSTALL_PATH}"
make packages/install/terraform-docs
echo "$INSTALL_PATH" >> $GITHUB_PATH
data:image/s3,"s3://crabby-images/f32e8/f32e85f027666416b654b0749258dcbce33cf974" alt="Jeremy G (Cloud Posse) avatar"
As I said, packages
had some bugs introduced with the arm64
support, but it should all be fixed now. I just ran make packages/install/terraform-docs
and it worked for me.
data:image/s3,"s3://crabby-images/f32e8/f32e85f027666416b654b0749258dcbce33cf974" alt="Jeremy G (Cloud Posse) avatar"
Right, that was a bug
• introduced in packages PR 3503 at 2023-04-02T2327Z and
• fixed in PR 3506 at 2023-04-03T2112Z
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
data:image/s3,"s3://crabby-images/f32e8/f32e85f027666416b654b0749258dcbce33cf974" alt="Jeremy G (Cloud Posse) avatar"
@Erik Osterman (Cloud Posse) @Andriy Knysh (Cloud Posse) FYI, for about 22 hours yesterday, make packages/install
was broken and either errored out (if run with /bin/sh
) or claimed the package was no longer supported. Anyone reporting such errors during that time period should simply be advised to try it again.