From ae0d3e66c4144527224d5883119695813bbfc816 Mon Sep 17 00:00:00 2001 From: Amanuel Engeda <74629455+engedaam@users.noreply.github.com> Date: Tue, 10 Dec 2024 13:01:49 -0800 Subject: [PATCH 1/2] chore: Drop deprecated AMI status condition (#7512) --- pkg/apis/v1/ec2nodeclass_status.go | 1 - pkg/controllers/nodeclass/status/ami.go | 11 ----------- pkg/controllers/nodeclass/status/ami_test.go | 3 --- test/suites/ami/suite_test.go | 1 - test/suites/drift/suite_test.go | 5 ++--- website/content/en/preview/concepts/nodeclasses.md | 3 +-- 6 files changed, 3 insertions(+), 21 deletions(-) diff --git a/pkg/apis/v1/ec2nodeclass_status.go b/pkg/apis/v1/ec2nodeclass_status.go index 7365f18e62d8..d122880cc612 100644 --- a/pkg/apis/v1/ec2nodeclass_status.go +++ b/pkg/apis/v1/ec2nodeclass_status.go @@ -23,7 +23,6 @@ const ( ConditionTypeSubnetsReady = "SubnetsReady" ConditionTypeSecurityGroupsReady = "SecurityGroupsReady" ConditionTypeAMIsReady = "AMIsReady" - ConditionTypeAMIsDeprecated = "AMIsDeprecated" ConditionTypeInstanceProfileReady = "InstanceProfileReady" ) diff --git a/pkg/controllers/nodeclass/status/ami.go b/pkg/controllers/nodeclass/status/ami.go index a6f9974880be..0d2dd0a2d904 100644 --- a/pkg/controllers/nodeclass/status/ami.go +++ b/pkg/controllers/nodeclass/status/ami.go @@ -65,17 +65,6 @@ func (a *AMI) Reconcile(ctx context.Context, nodeClass *v1.EC2NodeClass) (reconc } }) - // If deprecated AMIs are discovered set the AMIsDeprecated status condition - // If no deprecated AMIs are present, and previous status condition for AMIsDeprecated exists, remove the condition - hasDeprecatedAMIs := lo.Filter(nodeClass.Status.AMIs, func(ami v1.AMI, _ int) bool { - return ami.Deprecated - }) - hasDeprecatedCondition := nodeClass.StatusConditions().Get(v1.ConditionTypeAMIsDeprecated) != nil - if len(hasDeprecatedAMIs) > 0 { - nodeClass.StatusConditions().SetTrue(v1.ConditionTypeAMIsDeprecated) - } else if hasDeprecatedCondition { - _ = nodeClass.StatusConditions().Clear(v1.ConditionTypeAMIsDeprecated) - } nodeClass.StatusConditions().SetTrue(v1.ConditionTypeAMIsReady) return reconcile.Result{RequeueAfter: 5 * time.Minute}, nil } diff --git a/pkg/controllers/nodeclass/status/ami_test.go b/pkg/controllers/nodeclass/status/ami_test.go index 94fadca2eb53..31342d1f7b03 100644 --- a/pkg/controllers/nodeclass/status/ami_test.go +++ b/pkg/controllers/nodeclass/status/ami_test.go @@ -638,7 +638,6 @@ var _ = Describe("NodeClass AMI Status Controller", func() { }, }, )) - Expect(nodeClass.StatusConditions().IsTrue(v1.ConditionTypeAMIsDeprecated)).To(BeTrue()) Expect(nodeClass.StatusConditions().IsTrue(v1.ConditionTypeAMIsReady)).To(BeTrue()) }) It("should remove AMIDeprecated status condition when non deprecated AMIs are discovered", func() { @@ -678,7 +677,6 @@ var _ = Describe("NodeClass AMI Status Controller", func() { }, )) // Checks if both AMIsReady and AMIsDeprecated status conditions are set - Expect(nodeClass.StatusConditions().IsTrue(v1.ConditionTypeAMIsDeprecated)).To(BeTrue()) Expect(nodeClass.StatusConditions().IsTrue(v1.ConditionTypeAMIsReady)).To(BeTrue()) // rediscover AMIs again and reconcile @@ -740,7 +738,6 @@ var _ = Describe("NodeClass AMI Status Controller", func() { }, )) // Since all AMIs discovered are non deprecated, the status conditions should remove AMIsDeprecated and only set AMIsReady - Expect(nodeClass.StatusConditions().Get(v1.ConditionTypeAMIsDeprecated)).To(BeNil()) Expect(nodeClass.StatusConditions().IsTrue(v1.ConditionTypeAMIsReady)).To(BeTrue()) }) }) diff --git a/test/suites/ami/suite_test.go b/test/suites/ami/suite_test.go index 0af1df22f1fb..e102bbe823ea 100644 --- a/test/suites/ami/suite_test.go +++ b/test/suites/ami/suite_test.go @@ -178,7 +178,6 @@ var _ = Describe("AMI", func() { Expect(len(nc.Status.AMIs)).To(BeNumerically("==", 1)) Expect(nc.Status.AMIs[0].Deprecated).To(BeTrue()) ExpectStatusConditions(env, env.Client, 1*time.Minute, nodeClass, status.Condition{Type: v1.ConditionTypeAMIsReady, Status: metav1.ConditionTrue}) - ExpectStatusConditions(env, env.Client, 1*time.Minute, nodeClass, status.Condition{Type: v1.ConditionTypeAMIsDeprecated, Status: metav1.ConditionTrue}) }) It("should prioritize launch with non-deprecated AMIs", func() { nodeClass.Spec.AMIFamily = lo.ToPtr(v1.AMIFamilyAL2023) diff --git a/test/suites/drift/suite_test.go b/test/suites/drift/suite_test.go index 1de17b072b61..7e04968090dd 100644 --- a/test/suites/drift/suite_test.go +++ b/test/suites/drift/suite_test.go @@ -377,7 +377,8 @@ var _ = Describe("Drift", func() { By("validating the deprecated status condition has propagated") Eventually(func(g Gomega) { - g.Expect(nodeClass.StatusConditions().Get(v1.ConditionTypeAMIsDeprecated).IsTrue()).To(BeTrue()) + g.Expect(env.Client.Get(env.Context, client.ObjectKeyFromObject(nodeClass), nodeClass)).Should(Succeed()) + g.Expect(nodeClass.Status.AMIs[0].Deprecated).To(BeTrue()) g.Expect(nodeClass.StatusConditions().Get(v1.ConditionTypeAMIsReady).IsTrue()).To(BeTrue()) }).Should(Succeed()) @@ -397,10 +398,8 @@ var _ = Describe("Drift", func() { pod = env.EventuallyExpectHealthyPodCount(selector, numPods)[0] env.ExpectInstance(pod.Spec.NodeName).To(HaveField("ImageId", HaveValue(Equal(amdAMI)))) - By("validating the deprecated status condition has been removed") Eventually(func(g Gomega) { g.Expect(env.Client.Get(env.Context, client.ObjectKeyFromObject(nodeClass), nodeClass)).Should(Succeed()) - g.Expect(nodeClass.StatusConditions().Get(v1.ConditionTypeAMIsDeprecated)).To(BeNil()) g.Expect(nodeClass.StatusConditions().Get(v1.ConditionTypeAMIsReady).IsTrue()).To(BeTrue()) }).Should(Succeed()) }) diff --git a/website/content/en/preview/concepts/nodeclasses.md b/website/content/en/preview/concepts/nodeclasses.md index c3741f3a50f1..95fb29306f86 100644 --- a/website/content/en/preview/concepts/nodeclasses.md +++ b/website/content/en/preview/concepts/nodeclasses.md @@ -1566,8 +1566,7 @@ NodeClasses have the following status conditions: | SubnetsReady | Subnets are discovered. | | SecurityGroupsReady | Security Groups are discovered. | | InstanceProfileReady | Instance Profile is discovered. | -| AMIsReady | AMIs are discovered. | -| AMIsDeprecated | AMIs are discovered, but they are deprecated. Individual deprecated AMIs can be identified by reviewing the `status.amis`. | +| AMIsReady | AMIs are discovered. | | Ready | Top level condition that indicates if the nodeClass is ready. If any of the underlying conditions is `False` then this condition is set to `False` and `Message` on the condition indicates the dependency that was not resolved. | If a NodeClass is not ready, NodePools that reference it through their `nodeClassRef` will not be considered for scheduling. From ed929138ef2138cc358d7fb35d23163ac6209aa1 Mon Sep 17 00:00:00 2001 From: Jonathan Innis Date: Tue, 10 Dec 2024 14:38:13 -0800 Subject: [PATCH 2/2] chore: Only stale triage/needs-information and triage/solved issues (#7511) --- .github/workflows/stale.yaml | 30 ++++++++++++++++++++++++++---- 1 file changed, 26 insertions(+), 4 deletions(-) diff --git a/.github/workflows/stale.yaml b/.github/workflows/stale.yaml index fd2dc521b993..57ede4688342 100644 --- a/.github/workflows/stale.yaml +++ b/.github/workflows/stale.yaml @@ -12,13 +12,11 @@ jobs: if: github.repository == 'aws/karpenter-provider-aws' name: Stale issue bot steps: + # PR stale-out - uses: actions/stale@28ca1036281a5e5922ead5184a1bbf96e5fc984e # v9.0.0 with: repo-token: ${{ secrets.GITHUB_TOKEN }} - stale-issue-message: 'This issue has been inactive for 14 days. StaleBot will close this stale issue after 14 more days of inactivity.' - exempt-issue-labels: 'bug,chore,feature,documentation,testing,operational-excellence,automation,roadmap' - stale-issue-label: 'lifecycle/stale' - close-issue-label: 'lifecycle/closed' + only-issue-labels: 'ignore' # Ignore this step for Issues stale-pr-message: 'This PR has been inactive for 14 days. StaleBot will close this stale PR after 14 more days of inactivity.' exempt-pr-labels: 'blocked,needs-review,needs-design' stale-pr-label: 'lifecycle/stale' @@ -26,3 +24,27 @@ jobs: days-before-stale: 14 days-before-close: 14 operations-per-run: 300 + # Issue stale-out for "triage/needs-information" + - uses: actions/stale@28ca1036281a5e5922ead5184a1bbf96e5fc984e # v9.0.0 + with: + repo-token: ${{ secrets.GITHUB_TOKEN }} + stale-issue-message: 'This issue has been inactive for 14 days. StaleBot will close this stale issue after 14 more days of inactivity.' + only-issue-labels: 'triage/needs-information' + stale-issue-label: 'lifecycle/stale' + close-issue-label: 'lifecycle/closed' + only-pr-labels: 'ignore' # Ignore this step for PRs + days-before-stale: 14 + days-before-close: 14 + operations-per-run: 300 + # Issue stale-out for "triage/solved" + - uses: actions/stale@28ca1036281a5e5922ead5184a1bbf96e5fc984e # v9.0.0 + with: + repo-token: ${{ secrets.GITHUB_TOKEN }} + stale-issue-message: 'This issue has been inactive for 7 days and is marked as "triage/solved". StaleBot will close this stale issue after 7 more days of inactivity.' + only-issue-labels: 'triage/solved' + stale-issue-label: 'lifecycle/stale' + close-issue-label: 'lifecycle/closed' + only-pr-labels: 'ignore' # Ignore this step for PRs + days-before-stale: 7 + days-before-close: 7 + operations-per-run: 300