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

upcoming: [M3-9090] - Update existing v4/linodes/instances endpoints and types for Linode Interfaces project #11566

Merged
merged 23 commits into from
Feb 5, 2025

Conversation

coliu-akamai
Copy link
Contributor

@coliu-akamai coliu-akamai commented Jan 24, 2025

Description 📝

  • Updates existing /v4/linodes/instances endpoints for Linode Interfaces project

How to test 🧪

  • confirm changes match API spec
Author Checklists

As an Author, to speed up the review process, I considered 🤔

👀 Doing a self review
❔ Our contribution guidelines
🤏 Splitting feature into small PRs
➕ Adding a changeset
🧪 Providing/improving test coverage
🔐 Removing all sensitive information from the code and PR description
🚩 Using a feature flag to protect the release
👣 Providing comprehensive reproduction steps
📑 Providing or updating our documentation
🕛 Scheduling a pair reviewing session
📱 Providing mobile support
♿ Providing accessibility support


  • I have read and considered all applicable items listed above.

As an Author, before moving this PR from Draft to Open, I confirmed ✅

  • All unit tests are passing
  • TypeScript compilation succeeded without errors
  • Code passes all linting rules

Sorry, something went wrong.

@coliu-akamai coliu-akamai self-assigned this Jan 24, 2025
@coliu-akamai coliu-akamai force-pushed the m3-9090 branch 3 times, most recently from 856ac57 to f99c3b9 Compare January 28, 2025 21:38
@coliu-akamai coliu-akamai added the Help Wanted Teamwork makes the dream work! label Jan 28, 2025
@coliu-akamai coliu-akamai marked this pull request as ready for review January 28, 2025 22:32
@coliu-akamai coliu-akamai requested review from a team as code owners January 28, 2025 22:32
@coliu-akamai coliu-akamai requested review from dmcintyr-akamai, carrillo-erik, abailly-akamai and bnussman-akamai and removed request for a team January 28, 2025 22:32
Copy link

github-actions bot commented Jan 28, 2025

Coverage Report:
Base Coverage: 79.24%
Current Coverage: 79.25%

@coliu-akamai coliu-akamai added Add'tl Approval Needed Waiting on another approval! and removed Help Wanted Teamwork makes the dream work! labels Jan 29, 2025
@coliu-akamai
Copy link
Contributor Author

going to be testing out another approach - marking this as a draft for now 🙏

@coliu-akamai coliu-akamai marked this pull request as ready for review February 4, 2025 20:02
Copy link
Contributor Author

@coliu-akamai coliu-akamai left a comment

Choose a reason for hiding this comment

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

ultimately ended up with using a properties typeguard approach based on the purpose properties in the legacy Interface type as it felt a bit less complex than extending types

Comment on lines -34 to -35
// @TODO Linode Interfaces - follow up on if FirewallTemplate rules have the fingerprint / version fields.
// FirewallRules do, but the objects returned from the getFirewallTemplate requests don't
Copy link
Contributor Author

Choose a reason for hiding this comment

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

removed this comment bc it was answered in the spec (see [M3-9210] a list of api questions we're monitoring)

Copy link
Member

@bnussman-akamai bnussman-akamai left a comment

Choose a reason for hiding this comment

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

Nice. I'm happy with this! The typeguards are easy to follow and our code remains typesafe with little/no casting

Thanks for spending so much time on this! 🙏

Copy link
Contributor

@abailly-akamai abailly-akamai left a comment

Choose a reason for hiding this comment

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

Great! thank you for thoroughly consider different approaches here and coming up with a clean, well documented and readable solution ✅

* must be created in a region that supports the new interfaces.
*
* Default value on depends on interfaces_for_new_linodes field in AccountSettings object.
*/
Copy link
Contributor

Choose a reason for hiding this comment

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

🤟 🦸‍♀️

return (
interfaces === undefined ||
interfaces.length === 0 ||
interfaces.some((iface) => 'purpose' in iface)
Copy link
Contributor

Choose a reason for hiding this comment

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

'purpose' in iface - this made me smile

@bnussman-akamai bnussman-akamai added Approved Multiple approvals and ready to merge! and removed Add'tl Approval Needed Waiting on another approval! labels Feb 5, 2025
@linode-gh-bot
Copy link
Collaborator

Cloud Manager UI test results

🔺 1 failing test on test run #26 ↗︎

❌ Failing✅ Passing↪️ Skipped🕐 Duration
1 Failing493 Passing2 Skipped125m 38s

Details

Failing Tests
SpecTest
machine-image-upload.spec.tsmachine image » uploads machine image, mock expired upload event

Troubleshooting

Use this command to re-run the failing tests:

yarn cy:run -s "cypress/e2e/core/images/machine-image-upload.spec.ts"

@coliu-akamai coliu-akamai merged commit 86d7d8a into linode:develop Feb 5, 2025
22 of 23 checks passed
@coliu-akamai coliu-akamai deleted the m3-9090 branch February 5, 2025 18:40
Copy link

cypress bot commented Feb 5, 2025

Cloud Manager E2E    Run #7181

Run Properties:  status check passed Passed #7181  •  git commit 86d7d8a0c3: upcoming: [M3-9090] - Update existing `v4/linodes/instances` endpoints and types...
Project Cloud Manager E2E
Branch Review develop
Run status status check passed Passed #7181
Run duration 34m 05s
Commit git commit 86d7d8a0c3: upcoming: [M3-9090] - Update existing `v4/linodes/instances` endpoints and types...
Committer Connie Liu
View all properties for this run ↗︎

Test results
Tests that failed  Failures 0
Tests that were flaky  Flaky 6
Tests that did not run due to a developer annotating a test with .skip  Pending 2
Tests that did not run due to a failure in a mocha hook  Skipped 0
Tests that passed  Passing 500
View all changes introduced in this branch ↗︎

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Approved Multiple approvals and ready to merge! Linode Interfaces
Projects
None yet
Development

Successfully merging this pull request may close these issues.

None yet

5 participants