diff options
author | Panu Matilainen <pmatilai@redhat.com> | 2008-11-21 23:29:54 +0200 |
---|---|---|
committer | Panu Matilainen <pmatilai@redhat.com> | 2008-11-21 23:29:54 +0200 |
commit | ab3e32ad97e1c2143560ceb1aafb7c7bb85cfdcc (patch) | |
tree | c10f87d9d6624110297db4c85803766703e3c8fc /tests/rpmvercmp.at | |
parent | 357a7170fa04b5e28c75f4669689cd727b1cfd20 (diff) | |
download | rpm-ab3e32ad97e1c2143560ceb1aafb7c7bb85cfdcc.tar.gz rpm-ab3e32ad97e1c2143560ceb1aafb7c7bb85cfdcc.tar.bz2 rpm-ab3e32ad97e1c2143560ceb1aafb7c7bb85cfdcc.zip |
Add basic version comparison testing for install/upgrade
Diffstat (limited to 'tests/rpmvercmp.at')
-rw-r--r-- | tests/rpmvercmp.at | 96 |
1 files changed, 96 insertions, 0 deletions
diff --git a/tests/rpmvercmp.at b/tests/rpmvercmp.at new file mode 100644 index 000000000..08b8df8a7 --- /dev/null +++ b/tests/rpmvercmp.at @@ -0,0 +1,96 @@ +# rpmvercmp.at: rpm version comparison tests + +# ------------------------------ +# Test normal upgrade +AT_SETUP([rpm -U upgrade to newer]) +AT_CHECK([ +RPMDB_CLEAR +rm -rf "${TOPDIR}" + +for v in "1.0" "2.0"; do + run rpmbuild --quiet -bb \ + --define "ver $v" \ + ${RPMDATA}/SPECS/versiontest.spec +done + +runroot rpm -U "${TOPDIR}"/RPMS/noarch/versiontest-1.0-1.noarch.rpm +runroot rpm -U "${TOPDIR}"/RPMS/noarch/versiontest-2.0-1.noarch.rpm +], +[0], +[ignore], +[ignore]) +AT_CLEANUP + +# Test upgrading to older package (should fail) +AT_SETUP([rpm -U upgrade to older]) +AT_CHECK([ +RPMDB_CLEAR + +runroot rpm -U "${TOPDIR}"/RPMS/noarch/versiontest-2.0-1.noarch.rpm +runroot rpm -U "${TOPDIR}"/RPMS/noarch/versiontest-1.0-1.noarch.rpm +], +[2], +[ignore], +[ignore]) +AT_CLEANUP + +# Test downgrading to older package with --oldpackage +AT_SETUP([rpm -U --oldpackage downgrade]) +AT_CHECK([ +RPMDB_CLEAR + +runroot rpm -U "${TOPDIR}"/RPMS/noarch/versiontest-2.0-1.noarch.rpm +runroot rpm -U --oldpackage "${TOPDIR}"/RPMS/noarch/versiontest-1.0-1.noarch.rpm +], +[0], +[ignore], +[ignore]) +AT_CLEANUP + +# Test upgrade of different versions in same transaction +# XXX test that only 2.0-1 was installed +AT_SETUP([rpm -U two versions of same package]) +AT_CHECK([ +RPMDB_CLEAR + +runroot rpm -U \ + "${TOPDIR}"/RPMS/noarch/versiontest-1.0-1.noarch.rpm \ + "${TOPDIR}"/RPMS/noarch/versiontest-2.0-1.noarch.rpm +], +[0], +[ignore], +[ignore]) +AT_CLEANUP + +# Test install of two different versions in same transaction +# TODO: test that both got installed +AT_SETUP([rpm -i two versions of same package]) +AT_CHECK([ +RPMDB_CLEAR + +runroot rpm -i \ + "${TOPDIR}"/RPMS/noarch/versiontest-1.0-1.noarch.rpm \ + "${TOPDIR}"/RPMS/noarch/versiontest-2.0-1.noarch.rpm +], +[0], +[ignore], +[ignore]) +AT_CLEANUP + +# Test install of two different versions in same transaction +# TODO: test only one was installed +AT_SETUP([rpm -i identical versions of same package]) +AT_CHECK([ +RPMDB_CLEAR + +# TODO test just one was installed, this only emits warnings +runroot rpm -ivh \ + "${TOPDIR}"/RPMS/noarch/versiontest-1.0-1.noarch.rpm \ + "${TOPDIR}"/RPMS/noarch/versiontest-1.0-1.noarch.rpm +], +[0], +[ignore], +[ignore]) +AT_CLEANUP + +# TODO: the same with epoch vs no epoch |