mirror of
https://github.com/google/go-attestation.git
synced 2024-12-20 05:28:22 +00:00
Script setup of fake filesystem objects for tpm12 tests, fix build of tpm12 tests. (#5)
This commit is contained in:
parent
fc3b10963c
commit
790d3ba149
@ -99,8 +99,8 @@ func TestAIKCreateAndLoad(t *testing.T) {
|
||||
}
|
||||
}
|
||||
|
||||
// chooseEK selects the EK public which will be activated against.
|
||||
func chooseEK(t *testing.T, eks []PlatformEK) crypto.PublicKey {
|
||||
// chooseEKPub selects the EK public which will be activated against.
|
||||
func chooseEKPub(t *testing.T, eks []PlatformEK) crypto.PublicKey {
|
||||
t.Helper()
|
||||
|
||||
for _, ek := range eks {
|
||||
@ -129,7 +129,7 @@ func TestActivateCredentialTPM20(t *testing.T) {
|
||||
if err != nil {
|
||||
t.Fatalf("EKs() failed: %v", err)
|
||||
}
|
||||
ek := chooseEK(t, EKs)
|
||||
ek := chooseEKPub(t, EKs)
|
||||
|
||||
att, err := tpm2.DecodeAttestationData(aik.CreateAttestation)
|
||||
if err != nil {
|
||||
|
@ -150,7 +150,8 @@ func TestTPMQuote(t *testing.T) {
|
||||
t.Logf("Quote{version: %v, quote: %x, signature: %x}\n", quote.Version, quote.Quote, quote.Signature)
|
||||
}
|
||||
|
||||
func chooseEK(t *testing.T, eks []PlatformEK) []byte {
|
||||
// chooseEKCertRaw selects the EK cert which will be activated against.
|
||||
func chooseEKCertRaw(t *testing.T, eks []PlatformEK) []byte {
|
||||
t.Helper()
|
||||
|
||||
for _, ek := range eks {
|
||||
@ -186,7 +187,7 @@ func TestTPMActivateCredential(t *testing.T) {
|
||||
if err != nil {
|
||||
t.Fatalf("failed to read EKs: %v", err)
|
||||
}
|
||||
ekcert := chooseEK(t, EKs)
|
||||
ekcert := chooseEKCertRaw(t, EKs)
|
||||
|
||||
challenge.Credential, challenge.Secret, err = verification.GenerateChallenge(ekcert, aik.Public, nonce)
|
||||
if err != nil {
|
||||
|
78
ci/setup_tests_fs.sh
Executable file
78
ci/setup_tests_fs.sh
Executable file
@ -0,0 +1,78 @@
|
||||
#!/bin/bash
|
||||
#
|
||||
###############################################################################
|
||||
# Licensed under the Apache License, Version 2.0 (the "License");
|
||||
# you may not use this file except in compliance with the License.
|
||||
# You may obtain a copy of the License at
|
||||
#
|
||||
# http://www.apache.org/licenses/LICENSE-2.0
|
||||
#
|
||||
# Unless required by applicable law or agreed to in writing, software
|
||||
# distributed under the License is distributed on an "AS IS" BASIS,
|
||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
# See the License for the specific language governing permissions and
|
||||
# limitations under the License.
|
||||
################################################################################
|
||||
#
|
||||
# Sets up a root filesystem with files that symbolize the presence of a fake
|
||||
# hardware VM. This filesystem can be chrooted into to run tests.
|
||||
# USAGE: ./setup_tests_fs.sh <dir>
|
||||
set -e
|
||||
|
||||
BASE_DIR="${1%/}" # Trim any trailing slash.
|
||||
|
||||
setup_base () {
|
||||
if [[ ! -d "${BASE_DIR}" ]] && [[ -e "${BASE_DIR}" ]]; then
|
||||
>&2 echo "Error: '${BASE_DIR}' is not a directory."
|
||||
exit 1
|
||||
fi
|
||||
if [[ ! -e "${BASE_DIR}" ]]; then
|
||||
mkdir -pv "${BASE_DIR}"
|
||||
else
|
||||
sudo umount ${BASE_DIR}/* || true
|
||||
rm -rfv ${BASE_DIR}/*
|
||||
fi
|
||||
}
|
||||
|
||||
setup_mounts () {
|
||||
mkdir -v "${BASE_DIR}/bin"
|
||||
sudo mount --bind /bin "${BASE_DIR}/bin"
|
||||
mkdir -v "${BASE_DIR}/usr"
|
||||
sudo mount --bind /usr "${BASE_DIR}/usr"
|
||||
mkdir -v "${BASE_DIR}/var"
|
||||
sudo mount --bind /var "${BASE_DIR}/var"
|
||||
mkdir -v "${BASE_DIR}/tmp"
|
||||
sudo mount --bind /tmp "${BASE_DIR}/tmp"
|
||||
mkdir -v "${BASE_DIR}/lib"
|
||||
sudo mount --bind /lib "${BASE_DIR}/lib"
|
||||
mkdir -v "${BASE_DIR}/lib64"
|
||||
sudo mount --bind /lib64 "${BASE_DIR}/lib64"
|
||||
mkdir -v "${BASE_DIR}/dev"
|
||||
sudo mount --bind /dev "${BASE_DIR}/dev"
|
||||
mkdir -v "${BASE_DIR}/etc"
|
||||
sudo mount --bind /etc "${BASE_DIR}/etc"
|
||||
mkdir -v "${BASE_DIR}/opt"
|
||||
sudo mount --bind /opt "${BASE_DIR}/opt"
|
||||
mkdir -v "${BASE_DIR}/proc"
|
||||
sudo mount --bind /proc "${BASE_DIR}/proc"
|
||||
mkdir -v "${BASE_DIR}/root"
|
||||
sudo mount --bind /root "${BASE_DIR}/root"
|
||||
mkdir -v "${BASE_DIR}/run"
|
||||
sudo mount --bind /run "${BASE_DIR}/run"
|
||||
mkdir -v "${BASE_DIR}/home"
|
||||
sudo mount --bind /home "${BASE_DIR}/home"
|
||||
|
||||
if [[ -d "/tmpfs" ]]; then
|
||||
mkdir -v "${BASE_DIR}/tmpfs"
|
||||
sudo mount --bind /tmpfs "${BASE_DIR}/tmpfs"
|
||||
fi
|
||||
}
|
||||
|
||||
setup_sys_overlay () {
|
||||
mkdir -pv "${BASE_DIR}/sys/class/tpm/tpm0"
|
||||
touch "${BASE_DIR}/sys/class/tpm/tpm0/caps"
|
||||
}
|
||||
|
||||
setup_base
|
||||
setup_mounts
|
||||
setup_sys_overlay
|
Loading…
Reference in New Issue
Block a user