#spacelift (2023-08)
2023-08-01
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
settings.depends_on
is the atmos stack dependency. This does not work for creating spacelift dependencies.
What’s the official way to create dependencies in spacelift?
https://atmos.tools/cli/commands/describe/dependents/#description
This command produces a list of Atmos components in Atmos stacks that depend on the provided Atmos component.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
settings.spacelift.depends_on
This command produces a list of Atmos components in Atmos stacks that depend on the provided Atmos component.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
(we need to consolidate it with settings.depends_on
since settings.depends_on
was added recently and Spacelift modules/components were not updated to use it)
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
which one is going to win the battle? both?
if we moved to the spacelift version, will the atmos dependency cli runs still work?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
settings.depends_on
will be used, but for this all Spacelift odules and components will have to be updated
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
right. any timeline on that or is that not a planned update yet?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
not a high priority for us. Please use both for now. settings.depends_on
for the CLI, and settings.spacelift.depends_on
for Spacelift, and add TODO
to the code so you’ll update it later
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
ouch
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
wait…i could use anchors to not duplicate so might not be too bad
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
note that settings.depends_on
is used only in this command (which was added not too long ago) https://atmos.tools/cli/commands/describe/dependents, and nowhere else
This command produces a list of Atmos components in Atmos stacks that depend on the provided Atmos component.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
since it was added not to long ago, all other things were not updated to use settings.depends_on
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Spacelift has been using settings.spacelift.depends_on
for years
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
yeah, i did a full audit of depends_on
and consolidated on settings.depends_on
after upgrading Atmos.
I saw the page you linked and compared to https://atmos.tools/integrations/spacelift/#stack-configuration which does not mention depends_on
so I thought the above link was the right way for spacelift
Atmos natively supports Spacelift. This is accomplished using
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
if you are using it just for spacelift, use the old way
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
cc @matt @Dan Miller (Cloud Posse) if @johncblandii is using the GHA to detect affected stacks, he should probably define both, no?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
it’s not related to atmos describe affected
, it’s related to atmos describe dependents
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
but we need to update our spacelift components to use the new way of describing dependencies to make everything consistent (b/c stacks deps are not only related to Spacelift stacks, and the command atmos describe dependents
uses it to describe the dependencies using the CLI)
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
is there ever a case where settings.depends_on
would differ from settings.spacelift.depends_on
?
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
documentation on atmos.tools would be helpful too; specifically https://atmos.tools/integrations/spacelift/#stack-configuration
Atmos natively supports Spacelift. This is accomplished using
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
they have diff formats. The old one settings.spacelift.depends_on
(which our Spacelift components are using) is a list
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
settings.depends_on
is a map to support deep-merging and inheritance, and make the config DRY
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
yuppers. we stopped using 1: blah
and started doing this for ease of overrides:
settings:
depends_on:
cluster:
component: platform-ecs-cluster
ecs-tasks-mirror:
component: ecs-tasks-mirror
vpc:
component: vpc
2023-08-02
2023-08-08
2023-08-23
data:image/s3,"s3://crabby-images/1e7fb/1e7fb012e9114db9a49ef4fb0140243909a277f1" alt="Matt Gowie avatar"
Hey folks – with the spacelift-automation module / component, is there new functionality since 0.49.5
that will cancel stacked “trigger-policy” runs? As in it will do something similar to the below screenshot where if many runs are triggered due to dependencies, only the last will actually be planned?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
I know we definitely take advantage of it
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Is that not desired?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Cc @matt
data:image/s3,"s3://crabby-images/1e7fb/1e7fb012e9114db9a49ef4fb0140243909a277f1" alt="Matt Gowie avatar"
I’m interested in avoiding having to manually cancel the stacked runs to not bog down the Spacelift runs with clean plans. That’s what I’m getting at. Just wondering if there was ever an enhancement that made it in that helped avoid that. Haha I should probably just look at the release notes. I’ll dig into them sometime this week.
data:image/s3,"s3://crabby-images/7c49e/7c49e73b96e4b042edc4992c0ae9343ae1400e43" alt="Matt Calhoun avatar"
This should be a simple policy update…you can do something like the following…
cancel[run.id] {
run := input.in_progress[_]
run.type == "PROPOSED"
run.state == "QUEUED"
run.branch == input.pull_request.head.branch
}
data:image/s3,"s3://crabby-images/7c49e/7c49e73b96e4b042edc4992c0ae9343ae1400e43" alt="Matt Calhoun avatar"
Collaborative Infrastructure For Modern Software Teams