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

Test For command falco -i (ignore default events) #8

Merged
merged 8 commits into from
Apr 6, 2023
Merged

Test For command falco -i (ignore default events) #8

merged 8 commits into from
Apr 6, 2023

Conversation

Rohith-Raju
Copy link
Contributor

@Rohith-Raju Rohith-Raju commented Mar 29, 2023

This issue is related to #7,
Checkoff task

  • i

Implementation:

  • Move all the ignored events to the events.json file. The reason behind this was that if we were to store all the events in the test, it would look dirty.
  • Read the event.json file, loop over the events, and match with the regex expression.

@poiana
Copy link

poiana commented Mar 29, 2023

Welcome @Rohith-Raju! It looks like this is your first PR to falcosecurity/testing 🎉

@poiana poiana added the size/XL label Mar 29, 2023
Copy link
Collaborator

@jasondellaluce jasondellaluce left a comment

Choose a reason for hiding this comment

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

Thanks a ton for your first contribution! Much appreciated, specially in this repo!!

@@ -0,0 +1,278 @@
{
Copy link
Collaborator

Choose a reason for hiding this comment

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

This makes sense! What about putting this under a tests/data/outputs directory, and masking this through run.NewStringFileAccessor? That would allow the framework to carry around the test file in a runner-agnostic way (it will work whether Falco runs in a container or in the local machine). Accordingly, I would also add the deserialization code in the same package (the part of code responsible of converting the JSON in a Go struct). Take a look at how some of the existing test data is handled.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Sure, will do

}

runner := tests.NewFalcoExecutableRunner(t)
t.Run("all-events-ignored-by-default", func(t *testing.T) {
Copy link
Collaborator

Choose a reason for hiding this comment

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

Since we don't have other tests here, I would avoid having a sub-test with t.Run and would just proceed with the test code in the main TestFalco_Print_IgnoredEvents test body, what do you think?

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Test the behaviour and expected output of the Falco CLI depending on its options, considered both individually and in combinations:

Yes, since there no combinations for -i we can proceed with the main TestFalco_Print_IgnoredEvents

Comment on lines 141 to 154
type Data struct {
Events []string `json:"events"`
}
evntfile, err := os.Open("events.json")
if err != nil {
panic(err)
}
defer evntfile.Close()

var events Data
err = json.NewDecoder(evntfile).Decode(&events)
if err != nil {
panic(err)
}
Copy link
Collaborator

Choose a reason for hiding this comment

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

Look at the comment below: I think this should be part of the test data package under tests/data/outputs, so that it could be accessible by other tests as well and reused.

`Ignored\sEvent\(s\):\n`,
), res.Stdout())
for _, event := range events.Events {
assert.Regexp(t, regexp.MustCompile(`\b`+event+`\b`), res.Stdout())
Copy link
Collaborator

Choose a reason for hiding this comment

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

Maybe assert.Contains would be more lightweight here, since events are simple known strings. Remember, the more we make tests optimized, the less the CI will take to run them!

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Sure!

@@ -0,0 +1,278 @@
{
"events": [
Copy link
Collaborator

Choose a reason for hiding this comment

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

Out of curiosity, which Falco version did you use to generate this list?

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Falco version: 0.34.1
Libs version:  0.10.4
Plugin API:    2.0.0
Engine:        16
Driver:
  API version:    3.0.0
  Schema version: 2.0.0
  Default driver: 4.0.0+driver

Falco version: 0.34.1

@Rohith-Raju
Copy link
Contributor Author

Rohith-Raju commented Mar 30, 2023

Hi, @jasondellaluce thanks for reviewing my pr. I'll make the requested changes by Saturday as I'm caught up with college exams until tomorrow 😄

Signed-off-by: Rohith-Raju <[email protected]>
Events []string `json:"events"`
}

func deserialize() string {
Copy link
Collaborator

Choose a reason for hiding this comment

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

Since we have a fairly recent version of Go, let me suggest considering go:embed https://pkg.go.dev/embed. I think it's a better approach than going through runtime.Caller and reinvent the wheel in this case! What do you think?

Plus, if the only point of having a JSON file is to deserialize it and encode the inner list with comma-separated concatenation, why not just encoding all strings as comma-separated in a text file right away? This would also save you the trouble of defining a Data struct. I see the attempt of making something reusable, but I would suggest to 1) tackle reusability later when needed and keep the scope of this PR smaller, and 2) the JSON encoding is arbitrary, so it would be less intuitive for future contributors to reproduce.

TL;DR: Great work! My last suggestions are:

  1. Encode the file as a comma-separated text file containing the list of event names
  2. Include it in the project using go:embed, and then making it available through the NewStringFileAccessor construct like you already do.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Since we have a fairly recent version of Go, let me suggest considering go:embed https://pkg.go.dev/embed. I think it's a better approach than going through runtime.Caller and reinvent the wheel in this case! What do you think?

Oh, wow I didn't know something like this existed 😮 . Yes, this is great.

  1. Encode the file as a comma-separated text file containing the list of event names
  2. Include it in the project using go:embed, and then making it available through the NewStringFileAccessor construct like you already do.

Will do!!

@poiana poiana added size/M and removed size/XL labels Apr 3, 2023
@jasondellaluce
Copy link
Collaborator

Looks good now! Your test is failing in the latest version of Falco master. That's reasonable, because we're changing the logic with which events are selected/ignored for the next Falco release. Please make sure you use the latest master version of Falco to generate your syscall list (you can use the :master tag of the falcosecurity/falco-no-driver image).

@Rohith-Raju
Copy link
Contributor Author

Rohith-Raju commented Apr 4, 2023

Hey @jasondellaluce, So I exec ed into the falcosecurity/falco-no-driver:master and ran falco -i and it gave me these

root@933f5c41b8e2:/# falco -i
2023-04-04T14:57:26+0000: Falco version: 0.34.1-125+2b29ff7 (x86_64)
2023-04-04T14:57:26+0000: Falco initialized with configuration file: /etc/falco/falco.yaml
Ignored I/O syscall(s):
- recv
- pwrite64
- pread64
- sendfile64
- read
- write
- writev
- pwritev
- readv
- sendfile
- preadv
- sendto
- recvfrom
- send
- sendmsg
- recvmsg
- sendmmsg
- recvmmsg

I took these and re-generated the event file. I wasn't able to build falco master locally (ran into some build errors), so the tests are still using the old falco (which the tests are not passing) version and hence failing in my setup. Is there a way I can confirm my tests locally? I would love to know your local dev setup.

@jasondellaluce
Copy link
Collaborator

What error are you encountering when compiling Falco? Either way, you can install locally the latest dev version by downloading it from https://download.falco.org/?prefix=packages/bin-dev/. Then, once installed, the test suite should run successfully by following the readme instructions.

Either way, the tests are now just failing in the CI because your regex must be updated to match Ignored I/O syscall(s): instead of Ignored Events:. The restricted looks go to me, because from v0.35 onwards Falco will only effectively ignore IO-related system calls, whereas all the others will be activated dynamically based on the rulesets and config.

Signed-off-by: Rohith-Raju <[email protected]>
@Rohith-Raju
Copy link
Contributor Author

Oh, I see that there was a new image 14h ago. let me retry

Signed-off-by: Rohith-Raju <[email protected]>
@@ -0,0 +1 @@
recv,pwrite64,pread64,sendfile64,read,write,writev,pwritev,readv,sendfile,preadv,sendto,recvfrom,send,sendmsg,recvmsg,sendmmsg,recvmmsg
Copy link
Collaborator

Choose a reason for hiding this comment

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

Suggested change
recv,pwrite64,pread64,sendfile64,read,write,writev,pwritev,readv,sendfile,preadv,sendto,recvfrom,send,sendmsg,recvmsg,sendmmsg,recvmmsg
sendfile,pwritev,preadv,writev,read,pwrite,write,sendto,recv,send,sendmsg,recvfrom,recvmsg,pread,sendmmsg,recvmmsg,readv

The latest Falco dev fixed a couple of things, this should be the most up to date and hopefully definitive list.

Signed-off-by: Rohith-Raju <[email protected]>
@@ -0,0 +1 @@
sendfile,recvfrom,readv,sendto,send,read,recvmmsg,write,recvmsg,pwrite,sendmmsg,sendmsg,pread,writev,recv,pwritev,preadv
Copy link
Contributor Author

@Rohith-Raju Rohith-Raju Apr 5, 2023

Choose a reason for hiding this comment

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

@jasondellaluce my list is now matching with the latest list.

Copy link
Contributor Author

@Rohith-Raju Rohith-Raju Apr 5, 2023

Choose a reason for hiding this comment

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

What error are you encountering when compiling Falco? Either way, you can install locally the latest dev version by downloading it from https://download.falco.org/?prefix=packages/bin-dev/. Then, once installed, the test suite should run successfully by following the readme instructions.

There was some deps issue but now I've solved it. I built falco master and used the same for the test and it has since been passing. I think we are good for now @jasondellaluce

@Rohith-Raju Rohith-Raju mentioned this pull request Apr 6, 2023
3 tasks
Copy link
Collaborator

@jasondellaluce jasondellaluce left a comment

Choose a reason for hiding this comment

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

/approve

Thanks a lot and congrats for your first contribution here 🎉

@poiana
Copy link

poiana commented Apr 6, 2023

LGTM label has been added.

Git tree hash: 884a0c6714a4cd4aabb129d0c1fd34ac6d47e46a

@poiana
Copy link

poiana commented Apr 6, 2023

[APPROVALNOTIFIER] This PR is APPROVED

This pull-request has been approved by: jasondellaluce, Rohith-Raju

The full list of commands accepted by this bot can be found here.

The pull request process is described here

Needs approval from an approver in each of these files:

Approvers can indicate their approval by writing /approve in a comment
Approvers can cancel approval by writing /approve cancel in a comment

@poiana poiana added the approved label Apr 6, 2023
@poiana poiana merged commit 7e2011f into falcosecurity:main Apr 6, 2023
@Rohith-Raju
Copy link
Contributor Author

/approve

Thanks a lot and congrats for your first contribution here 🎉

Thank you more to come 😄

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants