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

WIP: Pointing libocispec to Jansson branch #1608

Open
wants to merge 6 commits into
base: switch-to-jansson
Choose a base branch
from

Conversation

xw19
Copy link
Contributor

@xw19 xw19 commented Nov 27, 2024

Trying out new libocispec with jansson

@xw19 xw19 changed the title Pointing libocispec to Jansson branch WIP: Pointing libocispec to Jansson branch Nov 27, 2024
@kwilczynski
Copy link
Member

@xw19, are you aware that we have decided that we are not going to be moving to a different JSON parser?

At least, to the best of my knowledge, we did.

@xw19
Copy link
Contributor Author

xw19 commented Nov 27, 2024

@xw19, are you aware that we have decided that we are not going to be moving to a different JSON parser?

At least, to the best of my knowledge, we did.

No, I am not aware of it. I have been working on the libocispec along with @saschagrunert for last few weeks.

@kwilczynski
Copy link
Member

@xw19, are you aware that we have decided that we are not going to be moving to a different JSON parser?
At least, to the best of my knowledge, we did.

No, I am not aware of it. I have been working on the libocispec along with @saschagrunert for last few weeks.

@xw19, see about clarifying the following:

Perhaps something has changed since then.

@saschagrunert
Copy link
Member

@kwilczynski we decided to replace it if the effort is overseeable. @xw19 did a great job over the past weeks working on this topic and I think we can benefit of switching over.

@kwilczynski
Copy link
Member

@kwilczynski we decided to replace it if the effort is overseeable. @xw19 did a great job over the past weeks working on this topic and I think we can benefit of switching over.

Do you mean "foreseeable" or "feasible", perhaps? Alas, I wasn't aware, as there wasn't any update on the linked issue about some work being done somewhere. I assumed that the old stance towards the work still stands. Any specific place where this is tracked now?

@saschagrunert
Copy link
Member

saschagrunert commented Nov 28, 2024

there wasn't any update on the linked issue about some work being done somewhere.

I was assuming this is enough: containers/libocispec#138 (comment)

Any specific place where this is tracked now?

Yes, still in containers/libocispec#138

@saschagrunert
Copy link
Member

@giuseppe do you mind approving this PR be be able to run in CI?

@kwilczynski
Copy link
Member

there wasn't any update on the linked issue about some work being done somewhere.

I was assuming this is enough: containers/libocispec#138 (comment)

Right. I have seen no more updates afterwards there, so I assume that nothing has happened since then.

@xw19, thank you for persevering and working on this.

@saschagrunert
Copy link
Member

We probably need a similar development branch for this repo like for libocispec.

@giuseppe
Copy link
Member

approved!

@xw19 thanks for your hard and important work

@kwilczynski having to statically link to yajl works but it is not ideal. If moving to a different library, that is supported, has no disadvantages then we must consider it.

The few things to consider for comparison that are important for crun:

  • no performance lost, we don't really parse much json, but it is important to make sure we don't regress here.
  • no memory leaks, even on the error paths, the fuzzing tests can help here.
  • no memory usage peaks.

@kwilczynski
Copy link
Member

[...]

@kwilczynski having to statically link to yajl works but it is not ideal. If moving to a different library, that is supported, has no disadvantages then we must consider it.

Sure, I simply wasn't sure where we were with it, and given that, I assumed we had given up.

The few things to consider for comparison that are important for crun:

* no performance lost, we don't really parse much json, but it is important to make sure we don't regress here.

* no memory leaks, even on the error paths, the fuzzing tests can help here.

* no memory usage peaks.

@giuseppe, anything from a security point of view to check here? Anything you can think of?

@giuseppe
Copy link
Member

giuseppe commented Dec 2, 2024

@giuseppe, anything from a security point of view to check here? Anything you can think of?

I think the fuzzing tests should cover this part too

@giuseppe
Copy link
Member

giuseppe commented Dec 2, 2024

@xw19 pointing to the jansson branch is enough or do we need to use any configure flag to enable it?

There are also some parts in crun that use directly yajl and we'd need to change them too

@xw19
Copy link
Contributor Author

xw19 commented Dec 2, 2024

pointing to the jansson branch is enough or do we need to use any configure flag to enable it?

I have just started to explore crun. So, will do whatever necessary.

There are also some parts in crun that use directly yajl and we'd need to change them too

Sure, will do thanks @giuseppe

Copy link

Ephemeral COPR build failed. @containers/packit-build please check.

@xw19
Copy link
Contributor Author

xw19 commented Dec 2, 2024

@giuseppe When I update any code the test suite doesn't run without giving explicit approvals. Can you help me by making the test cases run everytime I push the code?

@flouthoc
Copy link
Collaborator

flouthoc commented Dec 2, 2024

@giuseppe When I update any code the test suite doesn't run without giving explicit approvals. Can you help me by making the test cases run everytime I push the code?

I approved it, I think since this is your first PR here that's why github UI is doing this, but I'm sure there must be an option to approve by default for new contributors.

@xw19
Copy link
Contributor Author

xw19 commented Dec 2, 2024

I guess we need to modify pipelines to include jansson. I will do it after I am reasonably sure of my code.

@xw19
Copy link
Contributor Author

xw19 commented Dec 3, 2024

updates: WIP made changes to c files for yajl to jansson. Will continue to work on the same.

@xw19
Copy link
Contributor Author

xw19 commented Dec 11, 2024

Updates: wip able to compile, link started to fix unit tests

@xw19
Copy link
Contributor Author

xw19 commented Dec 12, 2024

Can anyone please approve this so that we can run the tests.

@saschagrunert
Copy link
Member

cc @giuseppe ☝️

src/libcrun/error.c Fixed Show fixed Hide fixed
src/libcrun/error.c Fixed Show fixed Hide fixed
src/libcrun/error.c Fixed Show fixed Hide fixed
src/libcrun/error.c Fixed Show fixed Hide fixed
@xw19
Copy link
Contributor Author

xw19 commented Dec 14, 2024

Updates: Fixed the dependencies and configurations. Resulting in CodeQL and other tests now able to run. Now realizing the breadth and scope of this task its huggggggggggggggge!

@xw19 xw19 force-pushed the main branch 12 times, most recently from 32be5f5 to 4de3033 Compare December 28, 2024 18:46
@xw19
Copy link
Contributor Author

xw19 commented Dec 28, 2024

@mrniranjan Thanks for pointing to right places and helping me to fix the podman test cases.

@xw19 xw19 force-pushed the main branch 2 times, most recently from f28a3b1 to dd1f26a Compare December 30, 2024 11:34
@xw19
Copy link
Contributor Author

xw19 commented Dec 30, 2024

@giuseppe @saschagrunert . I still need to fix the artificate and few fedora rpm tests. But can you start looking at the code?

Copy link

podman system tests failed. @containers/packit-build please check.

Copy link

Ephemeral COPR build failed. @containers/packit-build please check.

@xw19
Copy link
Contributor Author

xw19 commented Jan 3, 2025

/retest

Copy link

podman system tests failed. @containers/packit-build please check.

@xw19
Copy link
Contributor Author

xw19 commented Jan 3, 2025

@giuseppe @saschagrunert Please help on the artifact job. Apart from that I think I have all the things covered. I would like to work little bit more on the parsing numbers in the next PR.

Signed-off-by: Sourav Moitra <sourav.moitr@gmail.com>
@giuseppe
Copy link
Member

giuseppe commented Jan 7, 2025

please rebase your PR and drop the commits that do not belong to this change.

You can run git pull --rebase origin/main and make sure this PR has only the YAJL to Jansson patch

@giuseppe
Copy link
Member

giuseppe commented Jan 7, 2025

and thanks for the great work so far! :-)

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.

6 participants