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 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124
|
// -*- Mode: Go; indent-tabs-mode: t -*-
/*
* Copyright (C) 2017 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 builtin_test
import (
. "gopkg.in/check.v1"
"github.com/snapcore/snapd/interfaces"
"github.com/snapcore/snapd/interfaces/apparmor"
"github.com/snapcore/snapd/interfaces/builtin"
"github.com/snapcore/snapd/snap"
"github.com/snapcore/snapd/snap/snaptest"
"github.com/snapcore/snapd/testutil"
)
type ThumbnailerServiceInterfaceSuite struct {
iface interfaces.Interface
coreSlotInfo *snap.SlotInfo
coreSlot *interfaces.ConnectedSlot
classicSlotInfo *snap.SlotInfo
classicSlot *interfaces.ConnectedSlot
plugInfo *snap.PlugInfo
plug *interfaces.ConnectedPlug
}
var _ = Suite(&ThumbnailerServiceInterfaceSuite{
iface: builtin.MustInterface("thumbnailer-service"),
})
func (s *ThumbnailerServiceInterfaceSuite) SetUpTest(c *C) {
// a thumbnailer slot on a thumbnailer snap
const thumbnailerServiceMockCoreSlotSnapInfoYaml = `name: thumbnailer-service
version: 1.0
apps:
app:
command: foo
slots: [thumbnailer-service]
`
// a thumbnailer-service slot on the core snap (as automatically added on classic)
const thumbnailerServiceMockClassicSlotSnapInfoYaml = `name: core
version: 0
type: os
slots:
thumbnailer-service:
interface: thumbnailer-service
`
const mockPlugSnapInfo = `name: client
version: 1.0
apps:
app:
command: foo
plugs: [thumbnailer-service]
`
// thumbnailer-service snap with thumbnailer-service slot on an core/all-snap install.
snapInfo := snaptest.MockInfo(c, thumbnailerServiceMockCoreSlotSnapInfoYaml, nil)
s.coreSlotInfo = snapInfo.Slots["thumbnailer-service"]
s.coreSlot = interfaces.NewConnectedSlot(s.coreSlotInfo, nil, nil)
// thumbnailer-service slot on a core snap in a classic install.
snapInfo = snaptest.MockInfo(c, thumbnailerServiceMockClassicSlotSnapInfoYaml, nil)
s.classicSlotInfo = snapInfo.Slots["thumbnailer-service"]
s.classicSlot = interfaces.NewConnectedSlot(s.classicSlotInfo, nil, nil)
plugSnap := snaptest.MockInfo(c, mockPlugSnapInfo, nil)
s.plugInfo = plugSnap.Plugs["thumbnailer-service"]
s.plug = interfaces.NewConnectedPlug(s.plugInfo, nil, nil)
}
func (s *ThumbnailerServiceInterfaceSuite) TestName(c *C) {
c.Check(s.iface.Name(), Equals, "thumbnailer-service")
}
func (s *ThumbnailerServiceInterfaceSuite) TestUsedSecuritySystems(c *C) {
// connected slots have a non-nil security snippet for apparmor
apparmorSpec := &apparmor.Specification{}
err := apparmorSpec.AddConnectedSlot(s.iface, s.plug, s.coreSlot)
c.Assert(err, IsNil)
c.Assert(apparmorSpec.SecurityTags(), DeepEquals, []string{"snap.thumbnailer-service.app"})
c.Assert(apparmorSpec.SnippetForTag("snap.thumbnailer-service.app"), testutil.Contains, `interface=com.canonical.Thumbnailer`)
// slots have no permanent snippet on classic
apparmorSpec = &apparmor.Specification{}
err = apparmorSpec.AddConnectedSlot(s.iface, s.plug, s.classicSlot)
c.Assert(err, IsNil)
c.Assert(apparmorSpec.SecurityTags(), HasLen, 0)
// slots have a permanent non-nil security snippet for apparmor
apparmorSpec = &apparmor.Specification{}
err = apparmorSpec.AddPermanentSlot(s.iface, s.coreSlotInfo)
c.Assert(err, IsNil)
c.Assert(apparmorSpec.SecurityTags(), DeepEquals, []string{"snap.thumbnailer-service.app"})
c.Assert(apparmorSpec.SnippetForTag("snap.thumbnailer-service.app"), testutil.Contains, `member={RequestName,ReleaseName,GetConnectionCredentials}`)
}
func (s *ThumbnailerServiceInterfaceSuite) TestSlotGrantedAccessToPlugFiles(c *C) {
apparmorSpec := &apparmor.Specification{}
err := apparmorSpec.AddConnectedSlot(s.iface, s.plug, s.coreSlot)
c.Assert(err, IsNil)
c.Assert(apparmorSpec.SecurityTags(), DeepEquals, []string{"snap.thumbnailer-service.app"})
snippet := apparmorSpec.SnippetForTag("snap.thumbnailer-service.app")
c.Check(snippet, testutil.Contains, `@{INSTALL_DIR}/client/**`)
c.Check(snippet, testutil.Contains, `@{HOME}/snap/client/**`)
c.Check(snippet, testutil.Contains, `/var/snap/client/**`)
}
func (s *ThumbnailerServiceInterfaceSuite) TestInterfaces(c *C) {
c.Check(builtin.Interfaces(), testutil.DeepContains, s.iface)
}
|