mirror of
https://github.com/ostreedev/ostree.git
synced 2025-01-25 10:04:14 +03:00
6bf4b3e1d8
SPDX License List is a list of (common) open source licenses that can be referred to by a “short identifier”. It has several advantages compared to the common "license header texts" usually found in source files. Some of the advantages: * It is precise; there is no ambiguity due to variations in license header text * It is language neutral * It is easy to machine process * It is concise * It is simple and can be used without much cost in interpreted environments like java Script, etc. * An SPDX license identifier is immutable. * It provides simple guidance for developers who want to make sure the license for their code is respected See http://spdx.org for further reading. Signed-off-by: Marcus Folkesson <marcus.folkesson@gmail.com> Closes: #1439 Approved by: cgwalters
116 lines
4.2 KiB
Bash
Executable File
116 lines
4.2 KiB
Bash
Executable File
#!/bin/bash
|
||
#
|
||
# Copyright © 2017 Endless Mobile, Inc.
|
||
#
|
||
# SPDX-License-Identifier: LGPL-2.0+
|
||
#
|
||
# This library is free software; you can redistribute it and/or
|
||
# modify it under the terms of the GNU Lesser General Public
|
||
# License as published by the Free Software Foundation; either
|
||
# version 2 of the License, or (at your option) any later version.
|
||
#
|
||
# This library 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
|
||
# Lesser General Public License for more details.
|
||
#
|
||
# You should have received a copy of the GNU Lesser General Public
|
||
# License along with this library; if not, write to the
|
||
# Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
||
# Boston, MA 02111-1307, USA.
|
||
#
|
||
# Authors:
|
||
# - Philip Withnall <withnall@endlessm.com>
|
||
|
||
set -euo pipefail
|
||
|
||
. $(dirname $0)/libtest.sh
|
||
|
||
echo "1..2"
|
||
|
||
cd ${test_tmpdir}
|
||
mkdir repo
|
||
ostree_repo_init repo
|
||
|
||
mkdir -p tree/root
|
||
touch tree/root/a
|
||
|
||
# Add a few commits
|
||
seq 5 | while read i; do
|
||
echo a >> tree/root/a
|
||
${CMD_PREFIX} ostree --repo=repo commit --branch=test-$i -m test -s test tree
|
||
done
|
||
|
||
# Generate a plain summary file.
|
||
${CMD_PREFIX} ostree --repo=repo summary --update
|
||
|
||
# Generate a signed summary file.
|
||
${CMD_PREFIX} ostree --repo=repo summary --update --gpg-homedir=${TEST_GPG_KEYHOME} --gpg-sign=${TEST_GPG_KEYID_1}
|
||
|
||
# Try various ways of adding additional data.
|
||
${CMD_PREFIX} ostree --repo=repo summary --update --add-metadata key="'value'" --add-metadata=key2=true
|
||
${CMD_PREFIX} ostree --repo=repo summary --update -m some-int='@t 123'
|
||
${CMD_PREFIX} ostree --repo=repo summary --update --add-metadata=map='@a{sv} {}'
|
||
|
||
# Check the additional metadata turns up in the output.
|
||
${CMD_PREFIX} ostree --repo=repo summary --view > summary
|
||
assert_file_has_content summary "^map: {}$"
|
||
|
||
echo "ok 1 update summary"
|
||
|
||
# Test again, but with collections enabled in the repository (if supported).
|
||
if ! ostree --version | grep -q -e '- experimental'; then
|
||
echo "ok 2 # skip No experimental API is compiled in"
|
||
exit 0
|
||
fi
|
||
|
||
cd ${test_tmpdir}
|
||
rm -rf repo
|
||
ostree_repo_init repo --collection-id org.example.Collection1
|
||
|
||
mkdir -p tree/root
|
||
touch tree/root/a
|
||
|
||
# Add a few commits
|
||
seq 5 | while read i; do
|
||
echo a >> tree/root/a
|
||
${CMD_PREFIX} ostree --repo=repo commit --branch=test-$i -m test -s test tree
|
||
${CMD_PREFIX} ostree --repo=repo refs --collections --create=org.example.Collection2:test-$i test-$i
|
||
done
|
||
|
||
# Generate a plain summary file.
|
||
${CMD_PREFIX} ostree --repo=repo summary --update
|
||
|
||
# Generate a signed summary file.
|
||
${CMD_PREFIX} ostree --repo=repo summary --update --gpg-homedir=${TEST_GPG_KEYHOME} --gpg-sign=${TEST_GPG_KEYID_1}
|
||
|
||
# Try various ways of adding additional data.
|
||
${CMD_PREFIX} ostree --repo=repo summary --update --add-metadata key="'value'" --add-metadata=key2=true
|
||
${CMD_PREFIX} ostree --repo=repo summary --update -m some-int='@t 123'
|
||
${CMD_PREFIX} ostree --repo=repo summary --update --add-metadata=map='@a{sv} {}'
|
||
|
||
# Check the additional metadata turns up in the output.
|
||
${CMD_PREFIX} ostree --repo=repo summary --view > summary
|
||
assert_file_has_content summary "^map: {}$"
|
||
|
||
# Check the ostree-metadata ref has also been created with the same content and appropriate bindings.
|
||
${CMD_PREFIX} ostree --repo=repo refs --collections > refs
|
||
assert_file_has_content refs "^(org.example.Collection1, ostree-metadata)$"
|
||
|
||
${CMD_PREFIX} ostree --repo=repo show ostree-metadata --raw > metadata
|
||
assert_file_has_content metadata "'map': <@a{sv} {}>"
|
||
assert_file_has_content metadata "'ostree.ref-binding': <\['ostree-metadata'\]>"
|
||
assert_file_has_content metadata "'ostree.collection-binding': <'org.example.Collection1'>"
|
||
|
||
# There should be 5 commits in the ostree-metadata branch, since we’ve updated the summary 5 times.
|
||
${CMD_PREFIX} ostree --repo=repo log ostree-metadata | grep 'commit ' | wc -l > commit-count
|
||
assert_file_has_content commit-count "^5$"
|
||
|
||
# The ostree-metadata commits should not contain any files
|
||
${CMD_PREFIX} ostree --repo=repo ls ostree-metadata > files
|
||
assert_file_has_content files " /$"
|
||
cat files | wc -l > files-count
|
||
assert_file_has_content files-count "^1$"
|
||
|
||
echo "ok 2 update summary with collections"
|