1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108
|
// -*- Mode: Go; indent-tabs-mode: t -*-
/*
* Copyright (C) 2016 Canonical Ltd
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License version 3 as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*
*/
package apparmor
import (
"os"
apparmor_sandbox "github.com/snapcore/snapd/sandbox/apparmor"
"github.com/snapcore/snapd/snap"
"github.com/snapcore/snapd/testutil"
)
var (
NsProfile = nsProfile
ProfileGlobs = profileGlobs
SnapConfineFromSnapProfile = snapConfineFromSnapProfile
DefaultCoreRuntimeTemplateRules = defaultCoreRuntimeTemplateRules
DefaultOtherBaseTemplateRules = defaultOtherBaseTemplateRules
)
func MockLoadProfiles(f func(fnames []string, cacheDir string, flags apparmor_sandbox.AaParserFlags) error) (restore func()) {
r := testutil.Backup(&loadProfiles)
loadProfiles = f
return r
}
func MockRemoveCachedProfiles(f func(fnames []string, cacheDir string) error) (restore func()) {
r := testutil.Backup(&removeCachedProfiles)
removeCachedProfiles = f
return r
}
// MockProcSelfExe mocks the location of /proc/self/exe read by setupSnapConfineGeneratedPolicy.
func MockProcSelfExe(symlink string) (restore func()) {
old := procSelfExe
procSelfExe = symlink
return func() {
os.Remove(procSelfExe)
procSelfExe = old
}
}
// MockTemplate replaces apprmor template.
//
// NOTE: The real apparmor template is long. For testing it is convenient for
// replace it with a shorter snippet.
func MockTemplate(fakeTemplate string) (restore func()) {
orig := defaultCoreRuntimeTemplate
defaultCoreRuntimeTemplate = fakeTemplate
return func() { defaultCoreRuntimeTemplate = orig }
}
// MockClassicTemplate replaces the classic apprmor template.
func MockClassicTemplate(fakeTemplate string) (restore func()) {
orig := classicTemplate
classicTemplate = fakeTemplate
return func() { classicTemplate = orig }
}
// SetSpecScope sets the scope of a given specification
func SetSpecScope(spec *Specification, securityTags []string) (restore func()) {
return spec.setScope(securityTags)
}
func MockKernelFeatures(f func() ([]string, error)) (resture func()) {
old := kernelFeatures
kernelFeatures = f
return func() {
kernelFeatures = old
}
}
func MockParserFeatures(f func() ([]string, error)) (resture func()) {
old := parserFeatures
parserFeatures = f
return func() {
parserFeatures = old
}
}
func MockMetadataTagsSupported(f func() bool) (restore func()) {
return testutil.Mock(&metadataTagsSupported, f)
}
func (b *Backend) SetupSnapConfineReexec(info *snap.Info) error {
return b.setupSnapConfineReexec(info)
}
func (s *Specification) SnippetsForTag(tag string) []string {
return s.snippetsForTag(tag)
}
|