diff options
author | Colin Walters <walters@verbum.org> | 2013-07-09 11:28:49 -0400 |
---|---|---|
committer | Colin Walters <walters@verbum.org> | 2013-07-09 11:28:49 -0400 |
commit | 420763e90d3d3d98249cd41c8849e6c17f9a65ac (patch) | |
tree | af317303c08f4b7d169658adb07359b89e15c766 /tests/test-pull-corruption.sh | |
parent | 43d69ac8a38c3c5684134685586805224716d1bf (diff) | |
download | ostree-420763e90d3d3d98249cd41c8849e6c17f9a65ac.tar.gz |
tests: Add a test of corruption during a pull process
These corruption tests could be a lot better...like randomly try
single bit flips, range flips. Better, content-aware fuzzing. But
this is useful for now.
Diffstat (limited to 'tests/test-pull-corruption.sh')
-rwxr-xr-x | tests/test-pull-corruption.sh | 60 |
1 files changed, 60 insertions, 0 deletions
diff --git a/tests/test-pull-corruption.sh b/tests/test-pull-corruption.sh new file mode 100755 index 00000000..7a28cce8 --- /dev/null +++ b/tests/test-pull-corruption.sh @@ -0,0 +1,60 @@ +#!/bin/bash +# +# Copyright (C) 2011,2013 Colin Walters <walters@verbum.org> +# +# 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. + +set -e + +. $(dirname $0)/libtest.sh + +setup_fake_remote_repo1 "archive-z2" + +echo '1..1' + +repopath=${test_tmpdir}/ostree-srv/gnomerepo +cp -a ${repopath} ${repopath}.orig + +do_corrupt_pull_test() { + cd ${test_tmpdir} + rm repo -rf + mkdir repo + ${CMD_PREFIX} ostree --repo=repo init + ${CMD_PREFIX} ostree --repo=repo remote add origin $(cat httpd-address)/ostree/gnomerepo + if ${CMD_PREFIX} ostree --repo=repo pull origin main; then + assert_not_reached "pull unexpectedly succeeded!" + fi + rm -rf ${repopath} + cp -a ${repopath}.orig ${repopath} +} + +# Corrupt .dirmeta +someobject=$(find ${repopath} -name '*.dirmeta' | head -1) +echo "garbage garbage garbage" > ${someobject} +do_corrupt_pull_test +echo "ok corrupt dirmeta" + +# Corrupt .dirtree +someobject=$(find ${repopath} -name '*.dirtree' | head -1) +echo "garbage garbage garbage" > ${someobject} +do_corrupt_pull_test +echo "ok corrupt dirtree" + +# Corrupt .filez +someobject=$(find ${repopath} -name '*.filez' | head -1) +echo "garbage garbage garbage" > ${someobject} +do_corrupt_pull_test +echo "ok corrupt filez" |