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

Grackle adoptation for gokv tutorial #8

Merged
merged 28 commits into from
Jan 13, 2025
Merged

Conversation

mjschwenne
Copy link
Contributor

Hello!

I'm a PhD student working with Tej this semester on grackle, a tool which generates marshaling code and proofs from protobuf files. It's still a work in progress, but a lot of the basic features are complete and I've applied it to the gokv tutorial. Note that there are other proto files in the PR. Many of them needs features like slices which we're currently working on but aren't ready yet.

There is a new script update-grackle.sh which can run grackle and update the output. I've added a check to the CI workflow to ensure that the grackle output is kept up to date.

Please let me know if you have any questions or suggestions to improve this!

fi

# Have I mentioned that I dislike bash? Just look at this arcane
# and archaic syntax
Copy link
Contributor

Choose a reason for hiding this comment

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

Would this be nicer as a python script (especially if this gets more complex in the future)? E.g. something like Perennial's etc/update-goose.py.

Copy link
Member

Choose a reason for hiding this comment

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

I also would prefer to migrate this to python now rather than later. It's already at my personal limit for bash script complexity.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

I would also prefer that, although it was @tchajed who suggested bash in the first place. I will work on this shortly.

Copy link
Member

Choose a reason for hiding this comment

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

Sorry for flip flopping on that, I thought this would be simpler than it turned out.

@upamanyus
Copy link
Contributor

Cool! One thought: would it make sense to add (some variant of) ./update-grackle.sh to the default make target? Right now, I rely on running make before committing changes to make to make sure that nothing is broken, and it would be nice if that covered grackle-generated files as well.

One possibility is simply adding ./update-grackle.sh to the check target in the top-level Makefile, which would actually update the grackle-generated files. This seems nice since it's simple to implement and automatically fixes out-of-date files.

Another possibility would be to do some sort of read-only check in make check instead of updating the files. So if foo_gk.go is out of date, the read-only check would fail with an error instead of overwriting it with updated output. This seems nice since make check currently only "checks" stuff rather than modifying anything, and it would keep CI as simple as running make check.

fi

# Have I mentioned that I dislike bash? Just look at this arcane
# and archaic syntax
Copy link
Member

Choose a reason for hiding this comment

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

I also would prefer to migrate this to python now rather than later. It's already at my personal limit for bash script complexity.

@tchajed
Copy link
Member

tchajed commented Dec 4, 2024

I think adding a read-only check feature to grackle is a bit more complexity than necessary to do upstream.

I would like to integrate it into your make workflow. My suggestion would be to add an update-grackle target that runs the script; if you are okay with depending on grackle's dependencies (which I believe is to have protoc installed) then we can also make that part of the default target. We can do a little more work in CI to call make update-grackle and check afterward that git status is empty; we use that approach in other places and I think adding a little more complexity to the CI checks isn't a big deal.

@mjschwenne
Copy link
Contributor Author

if you are okay with depending on grackle's dependencies (which I believe is to have protoc installed)

Correct, that is the only external dependency for grackle.

I'd be happy to integrate grackle checking into the makefile. As Tej mentioned, grackle doesn't currently support checking output without writing it, although it may be possible to bootstrap the --debug flag which prints the grackle output to standard out for this purpose.

The easiest option at the moment is probably to add ./update-grackle.sh to the fix make rule and utilize the new CI job to check that the grackle output is up to date if you would like to avoid make check updating files. Otherwise, we could add the grackle updates to make check as well.

Something else to keep in mind is that grackle is still being developed and it's possible that my changes to upstream grackle will cause the CI job to fail even if no other changes to the grackled portion of gokv are made. We may want to change the @latest tag to some fixed commit but that runs the risk of missing new features.

@tchajed
Copy link
Member

tchajed commented Dec 6, 2024

Looks like you forgot to add the python script (update-gracke.py). Also the github workflow should reference the new file and not the sh script.

I agree that using a tagged version is safer, to avoid CI failures while grackle is rapidly changing. We can still bump that version regularly.

@tchajed
Copy link
Member

tchajed commented Jan 13, 2025

@upamanyus I'd like to merge this soon, unless you can see any problems it would create.

CI is now passing and all the review concerns above have been addressed. The corresponding Perennial PR (mit-pdos/perennial#150) will synchronize it with the new code, and we can quickly get it merged once this is in.

@upamanyus upamanyus merged commit 05dfe0e into mit-pdos:main Jan 13, 2025
2 checks passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants