mirror of
https://github.com/roddhjav/apparmor.d.git
synced 2024-12-30 17:07:07 +01:00
59ac54e2fc
- ABI4 by default, fallback to abi 3. - aa-prebuild cli that can be used by other project shipping profiles. - --file option to cli to only build one dev profile. - add abi version filter to only & exclude directives.
82 lines
1.8 KiB
Go
82 lines
1.8 KiB
Go
// apparmor.d - Full set of apparmor profiles
|
|
// Copyright (C) 2021-2024 Alexandre Pujol <alexandre@pujol.io>
|
|
// SPDX-License-Identifier: GPL-2.0-only
|
|
|
|
package directive
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"github.com/roddhjav/apparmor.d/pkg/paths"
|
|
"github.com/roddhjav/apparmor.d/pkg/prebuild"
|
|
)
|
|
|
|
func TestStack_Apply(t *testing.T) {
|
|
tests := []struct {
|
|
name string
|
|
rootApparmord *paths.Path
|
|
opt *Option
|
|
profile string
|
|
want string
|
|
wantErr bool
|
|
}{
|
|
{
|
|
name: "stack",
|
|
rootApparmord: paths.New("../../../apparmor.d/groups/freedesktop/"),
|
|
opt: &Option{
|
|
Name: "stack",
|
|
ArgMap: map[string]string{"plymouth": ""},
|
|
ArgList: []string{"plymouth"},
|
|
File: nil,
|
|
Raw: " #aa:stack plymouth",
|
|
},
|
|
profile: `
|
|
profile parent @{exec_path} {
|
|
include <abstractions/base>
|
|
|
|
@{exec_path} mr,
|
|
|
|
#aa:stack plymouth
|
|
@{bin}/plymouth rPx -> parent//&plymouth,
|
|
|
|
@{PROC}/cmdline r,
|
|
|
|
include if exists <local/parent>
|
|
}`,
|
|
want: `
|
|
profile parent @{exec_path} {
|
|
include <abstractions/base>
|
|
|
|
@{exec_path} mr,
|
|
|
|
|
|
@{bin}/plymouth rPx -> parent//&plymouth,
|
|
|
|
@{PROC}/cmdline r,
|
|
|
|
# Stacked profile: plymouth
|
|
include <abstractions/fonts>
|
|
include <abstractions/fontconfig-cache-read>
|
|
include <abstractions/consoles>
|
|
unix (send, receive, connect) type=stream peer=(addr="@/org/freedesktop/plymouthd"),
|
|
@{PROC}/cmdline r,
|
|
include if exists <local/plymouth>
|
|
|
|
include if exists <local/parent>
|
|
}`,
|
|
},
|
|
}
|
|
for _, tt := range tests {
|
|
t.Run(tt.name, func(t *testing.T) {
|
|
prebuild.RootApparmord = tt.rootApparmord
|
|
got, err := Directives["stack"].Apply(tt.opt, tt.profile)
|
|
if (err != nil) != tt.wantErr {
|
|
t.Errorf("Stack.Apply() error = %v, wantErr %v", err, tt.wantErr)
|
|
return
|
|
}
|
|
if got != tt.want {
|
|
t.Errorf("Stack.Apply() = %v, want %v", got, tt.want)
|
|
}
|
|
})
|
|
}
|
|
}
|