|
3 | 3 | package seccomp |
4 | 4 |
|
5 | 5 | import ( |
| 6 | + "bytes" |
6 | 7 | "errors" |
7 | 8 | "fmt" |
| 9 | + "io" |
8 | 10 | "os" |
9 | 11 | "os/exec" |
10 | 12 | "strings" |
@@ -773,6 +775,64 @@ func subprocessCreateActKillProcessFilter(t *testing.T) { |
773 | 775 | } |
774 | 776 | } |
775 | 777 |
|
| 778 | +func TestExportBPF(t *testing.T) { |
| 779 | + execInSubprocess(t, subprocessExportBPF) |
| 780 | +} |
| 781 | + |
| 782 | +func subprocessExportBPF(t *testing.T) { |
| 783 | + filter, err := NewFilter(ActAllow) |
| 784 | + if err != nil { |
| 785 | + t.Fatalf("Error creating filter: %s", err) |
| 786 | + } |
| 787 | + defer filter.Release() |
| 788 | + |
| 789 | + call, err := GetSyscallFromName("getpid") |
| 790 | + if err != nil { |
| 791 | + t.Fatalf("Error getting syscall number of getpid: %s", err) |
| 792 | + } |
| 793 | + |
| 794 | + err = filter.AddRule(call, ActErrno.SetReturnCode(42)) |
| 795 | + if err != nil { |
| 796 | + t.Fatalf("Error adding rule: %s", err) |
| 797 | + } |
| 798 | + |
| 799 | + file, err := os.Create(t.TempDir() + "/bpf") |
| 800 | + if err != nil { |
| 801 | + t.Fatal(err) |
| 802 | + } |
| 803 | + defer file.Close() |
| 804 | + |
| 805 | + err = filter.ExportBPF(file) |
| 806 | + if err != nil { |
| 807 | + t.Fatalf("ExportBPF: %v", err) |
| 808 | + } |
| 809 | + |
| 810 | + if _, err := file.Seek(0, io.SeekStart); err != nil { |
| 811 | + t.Fatal(err) |
| 812 | + } |
| 813 | + contents, err := io.ReadAll(file) |
| 814 | + if err != nil { |
| 815 | + t.Fatal(err) |
| 816 | + } |
| 817 | + t.Logf("ExportBPF: size %d", len(contents)) |
| 818 | + |
| 819 | + expErr := error(nil) |
| 820 | + // ExportBPFMem needs seccomp 2.6.0. |
| 821 | + if checkAPI(t.Name(), 0, 2, 6, 0) != nil { |
| 822 | + expErr = syscall.EOPNOTSUPP |
| 823 | + } |
| 824 | + contentsMem, err := filter.ExportBPFMem() |
| 825 | + if err != expErr { |
| 826 | + t.Errorf("ExportBPFMem: want %v, got %v", expErr, err) |
| 827 | + } |
| 828 | + if err == nil { |
| 829 | + t.Logf("ExportBPFMem: size %d", len(contents)) |
| 830 | + if !bytes.Equal(contents, contentsMem) { |
| 831 | + t.Errorf("Got different data from ExportBPF and ExportBPFMem (%v != %v)", contents, contentsMem) |
| 832 | + } |
| 833 | + } |
| 834 | +} |
| 835 | + |
776 | 836 | // |
777 | 837 | // Seccomp notification tests |
778 | 838 | // |
|
0 commit comments