diff options
Diffstat (limited to 'tests.as-root')
3 files changed, 157 insertions, 0 deletions
diff --git a/tests.as-root/building-a-system-branch-picks-up-committed-removes.script b/tests.as-root/building-a-system-branch-picks-up-committed-removes.script new file mode 100755 index 00000000..b593eabd --- /dev/null +++ b/tests.as-root/building-a-system-branch-picks-up-committed-removes.script @@ -0,0 +1,57 @@ +#!/bin/bash +# Copyright (C) 2013 Codethink Limited +# +# This program is free software; you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation; version 2 of the License. +# +# 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, write to the Free Software Foundation, Inc., +# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. + +set -e + +. "$SRCDIR/tests.as-root/setup-build" +KERNEL_BRANCH=baserock/builds/123456789/AABBCCDDE + +cd "$DATADIR/workspace/branch1/test:kernel-repo" +git checkout --quiet master +echo Use Morph >README +git add README +git commit --quiet -m 'Add README' + +# Build the linux system from the system branch. +cd "$DATADIR/workspace" +"$SRCDIR/scripts/test-morph" build linux-system + +# Make a change elsewhere to be pulled in +PEER_REPO="$DATADIR/peer-kernel" +git clone --quiet "file://$DATADIR/workspace/branch1/test:kernel-repo" \ + "$PEER_REPO" +cd "$PEER_REPO" +git checkout --quiet -b fix +# remove useless README +git rm --quiet README +git commit --quiet -m 'change stuff' +git checkout --quiet master +git merge --no-ff fix >/dev/null 2>&1 + +# Pull a commit in to the linux morphology. +cd "$DATADIR/workspace/branch1/test:kernel-repo" +git remote add peer "file://$PEER_REPO" +git remote update >/dev/null 2>&1 +git merge --quiet peer/master + +# Build the linux system again without comitting. +cd "$DATADIR/workspace" +"$SRCDIR/scripts/test-morph" build linux-system +cd branch1/test:kernel-repo + +# Check whether the new morphology exists in the temporary build ref +cd "$DATADIR/workspace/branch1/test:kernel-repo" +! git cat-file blob "$KERNEL_BRANCH:README" >/dev/null 2>&1 diff --git a/tests.as-root/metadata-includes-morph-version.script b/tests.as-root/metadata-includes-morph-version.script new file mode 100755 index 00000000..f83712a7 --- /dev/null +++ b/tests.as-root/metadata-includes-morph-version.script @@ -0,0 +1,52 @@ +#!/bin/sh +# +# Copyright (C) 2013 Codethink Limited +# +# This program is free software; you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation; version 2 of the License. +# +# 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, write to the Free Software Foundation, Inc., +# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. + + +# All the metadata files in /baserock of a system contain morph's version +# information + +set -eu + +# Disable test on versions of Python before 2.7. +. "$SRCDIR/scripts/python-check" + +. "$SRCDIR/scripts/fix-committer-info" + +# get git version info +cd "$SRCDIR" +description="$(git describe --always --dirty=-unreproducible)" +commit="$(git rev-parse 'HEAD^{commit}')" +tree="$(git rev-parse 'HEAD^{tree}')" +ref="$(git rev-parse --symbolic-full-name 'HEAD')" + +tar=$("$SRCDIR/scripts/test-morph" --find-system-artifact \ + build-morphology test:morphs tarball hello-tarball) + +extracted="$DATADIR/extracted" +mkdir -p "$extracted" +tar -xf "$tar" -C "$extracted" +cd "$extracted/baserock" +for f in *.meta; do + # Check for git describe output + grep -q -F -e "$description" "$f" + # Check the Sha-1 commit is included + grep -q -F -e "$commit" "$f" + # Check the Sha-1 of the commit's tree is included + grep -q -F -e "$tree" "$f" + # Check the ref (e.g. branch) is included + grep -q -F -e "$ref" "$f" +done diff --git a/tests.as-root/metadata-includes-morph-version.setup b/tests.as-root/metadata-includes-morph-version.setup new file mode 100755 index 00000000..2284cfb9 --- /dev/null +++ b/tests.as-root/metadata-includes-morph-version.setup @@ -0,0 +1,48 @@ +#!/bin/bash +# +# Copyright (C) 2013 Codethink Limited +# +# This program is free software; you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation; version 2 of the License. +# +# 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, write to the Free Software Foundation, Inc., +# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. + + +set -eu + +source "$SRCDIR/scripts/fix-committer-info" + +morphsrepo="$DATADIR/morphs" +cd "$morphsrepo" +git checkout -b tarball +cat <<EOF > hello-tarball.morph +{ + "name": "hello-tarball", + "kind": "system", + "system-kind": "rootfs-tarball", + "arch": "$(uname -m)", + "strata": [ + { + "morph": "hello-stratum", + "repo": "test:morphs", + "ref": "master" + }, + { + "morph": "linux-stratum", + "repo": "test:morphs", + "ref": "master" + } + ] +} +EOF +git add hello-tarball.morph + +git commit --quiet -m "add tarball system" |