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

feat(dev): observation print commands #762

Merged
merged 18 commits into from
Nov 7, 2024

Conversation

meganwolf0
Copy link
Collaborator

Description

Dev commands to print the associated resources and validation provided an Observation UUID

  • Primary intent is to more easily identify associated resources/validation from observations when they don't pass - additional context is this was initially an effort for dash days to have automation surrounding previously passing, now failing observations/validations
  • Limitation on the print-validation command is that the component definition must be composed, so the ID can be referenced from the back-matter. This is probably a larger can of worms on supporting the file path in that prop, but I feel like right now the cleanest case is to enforce that it must be composed

Related Issue

Fixes #621

Type of change

  • Bug fix (non-breaking change which fixes an issue)
  • New feature (non-breaking change which adds functionality)
  • Other (security config, docs update, etc)

Checklist before merging

@meganwolf0 meganwolf0 self-assigned this Oct 25, 2024
@meganwolf0 meganwolf0 marked this pull request as ready for review October 25, 2024 10:06
@meganwolf0 meganwolf0 requested a review from a team as a code owner October 25, 2024 10:06
@mildwonkey
Copy link
Contributor

Seeing as we're re-using the print suffix, what do you think about lula dev print as a subcommand that takes either flags or arguments to identify what it's printing? Ie lula dev print --validation=<>, or lula dev print resource? (as a future feature we could then allow multiple print statements in one command)

@meganwolf0
Copy link
Collaborator Author

Seeing as we're re-using the print suffix, what do you think about lula dev print as a subcommand that takes either flags or arguments to identify what it's printing? Ie lula dev print --validation=<>, or lula dev print resource? (as a future feature we could then allow multiple print statements in one command)

Yeah looking back at the commands, there's a ton of logic overlap so that might be a fair way to refactor that. Let me poke at that a bit more and throw this back up

@meganwolf0 meganwolf0 marked this pull request as draft October 30, 2024 12:58
@meganwolf0 meganwolf0 marked this pull request as ready for review October 30, 2024 14:10
@meganwolf0
Copy link
Collaborator Author

@mildwonkey it's been thrown up 🤮 🤣

@mildwonkey
Copy link
Contributor

I like it!! I think you still need to update the lula_dev docs but otherwise 👩🏻‍🍳 💋

Copy link
Member

@brandtkeller brandtkeller left a comment

Choose a reason for hiding this comment

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

The logic itself I don't have much in the way of concerns. I'd like to document the constraints around composed component definitions as that looks like an obvious "gotcha" that will occur.

Otherwise my primary concern is command location - does a sub-command of dev feel appropriate here if the story we've been telling to-date is that dev is meant for validations and separate/distinct from OSCAL?

@meganwolf0
Copy link
Collaborator Author

meganwolf0 commented Nov 5, 2024

The logic itself I don't have much in the way of concerns. I'd like to document the constraints around composed component definitions as that looks like an obvious "gotcha" that will occur.

Sounds good, I'll update the command help to try and highlight that constraint more. Might also add like a message to the user if a validation isn't found that the user should check they're using the composed component defn.

Actually, I just added the compose to that step - the wrinkle to that is that it doesn't currently support templating, but that might be something we can add via #771 ?

Otherwise my primary concern is command location - does a sub-command of dev feel appropriate here if the story we've been telling to-date is that dev is meant for validations and separate/distinct from OSCAL?

I guess I wasn't thinking dev was explicitly for validations, although I suppose that is all the functions at the moment, I think I was considering it more like as developer helper functions... but could do a different top level command for these? Or could just make the print it's own top level thing.

Our help text for dev is "Collection of dev commands to make dev life easier", our help text for tools is "Collection of additional commands to make OSCAL easier"... feels like this is a little of both haha, although print logic is more lula <> OSCAL specific rather than standalone OSCAL (since we're relaying on specific props/links) so maybe tools doesn't make sense either.

@brandtkeller
Copy link
Member

Actually, I just added the compose to that step - the wrinkle to that is that it doesn't currently support templating, but that might be something we can add via #771 ?

That sounds good.

Our help text for dev is "Collection of dev commands to make dev life easier", our help text for tools is "Collection of additional commands to make OSCAL easier"... feels like this is a little of both haha, although print logic is more lula <> OSCAL specific rather than standalone OSCAL (since we're relaying on specific props/links) so maybe tools doesn't make sense either.

My wanting to think about command locality is still an open question that I've made for if lula dev could be used to support validation workflows without OSCAL - highlighting the value of the validations in isolation.

lula tools is typically where we have been dropping OSCAL helpers outside of the core functionality. That could be a contender? Optimally the Logic having a primary focus on OSCAL means that it would operate on OSCAL generically and lacking the required information would not outright error.

(maybe not in scope today) - This highlights another area of opportunity which is documenting the design - as this may be Lula opinionation today - but something we should look to have available for review and standardization from the OSCAL community provided there was interest - either in changing our logic or others following the pattern.

@meganwolf0
Copy link
Collaborator Author

@brandtkeller went ahead and moved the commands to tools, lmk if you think that fits better

Copy link
Member

@brandtkeller brandtkeller left a comment

Choose a reason for hiding this comment

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

Minor conflict to resolve

@meganwolf0 meganwolf0 marked this pull request as draft November 7, 2024 16:43
@meganwolf0
Copy link
Collaborator Author

Super minor change - moved the WriteResources function down to src/types as that felt like a better fit... after getting deep in the validation tests/this dir in particular, it feels like a good step toward a slow disaggregation of that types.go into more relevant names :clarity-is-kindness:

@meganwolf0 meganwolf0 marked this pull request as ready for review November 7, 2024 16:58
Copy link
Contributor

@mildwonkey mildwonkey left a comment

Choose a reason for hiding this comment

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

I like the organizational changes!

@brandtkeller brandtkeller merged commit 0e9337e into main Nov 7, 2024
10 checks passed
@brandtkeller brandtkeller deleted the 621-dev-observation-print-commands branch November 7, 2024 18:01
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
Status: ✅ Done
Development

Successfully merging this pull request may close these issues.

Dev commands to extract validation and resources by observation uuid
3 participants