1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
|
#!/usr/bin/python
import sys
import os
import glob
import os.path
from subprocess import call, PIPE
import unittest
stdout = os.open("/dev/null",0) #sys.stdout
stderr = os.open("/dev/null",0) # sys.stderr
apt_args = [] # ["-o","Debug::pkgAcquire::Auth=true"]
class testAuthentication(unittest.TestCase):
# some class wide data
apt = "apt-get"
pkg = "libglib2.0-data"
pkgver = "2.13.6-1ubuntu1"
pkgpath = "/var/cache/apt/archives/libglib2.0-data_2.13.6-1ubuntu1_all.deb"
def setUp(self):
for f in glob.glob("testkeys/*,key"):
call(["apt-key", "add", f], stdout=stdout, stderr=stderr)
def _cleanup(self):
" make sure we get new lists and no i-m-s "
call(["rm","-f", "/var/lib/apt/lists/*"])
if os.path.exists(self.pkgpath):
os.unlink(self.pkgpath)
def _expectedRes(self, resultstr):
if resultstr == 'ok':
return 0
elif resultstr == 'broken':
return 100
def testPackages(self):
for f in glob.glob("testsources.list/sources.list*package*"):
self._cleanup()
(prefix, testtype, result) = f.split("-")
expected_res = self._expectedRes(result)
# update first
call([self.apt,"update",
"-o","Dir::Etc::sourcelist=./%s" % f]+apt_args,
stdout=stdout, stderr=stderr)
# then get the pkg
cmd = ["install", "-y", "-d", "--reinstall",
"%s=%s" % (self.pkg, self.pkgver),
"-o","Dir::state::Status=./fake-status"]
res = call([self.apt, "-o","Dir::Etc::sourcelist=./%s" % f]+cmd+apt_args,
stdout=stdout, stderr=stderr)
self.assert_(res == expected_res,
"test '%s' failed (got %s expected %s" % (f,res,expected_res))
def testGPG(self):
for f in glob.glob("testsources.list/sources.list*gpg*"):
self._cleanup()
(prefix, testtype, result) = f.split("-")
expected_res = self._expectedRes(result)
# update first
call([self.apt,"update",
"-o","Dir::Etc::sourcelist=./%s" % f]+apt_args,
stdout=stdout, stderr=stderr)
# then get the pkg
cmd = ["install", "-y", "-d", "--reinstall",
"%s=%s" % (self.pkg, self.pkgver),
"-o","Dir::state::Status=./fake-status"]
res = call([self.apt, "-o","Dir::Etc::sourcelist=./%s" % f]+
cmd+apt_args,
stdout=stdout, stderr=stderr)
self.assert_(res == expected_res,
"test '%s' failed (got %s expected %s" % (f,res,expected_res))
def testRelease(self):
for f in glob.glob("testsources.list/sources.list*release*"):
self._cleanup()
(prefix, testtype, result) = f.split("-")
expected_res = self._expectedRes(result)
cmd = ["update"]
res = call([self.apt,"-o","Dir::Etc::sourcelist=./%s" % f]+cmd+apt_args,
stdout=stdout, stderr=stderr)
self.assert_(res == expected_res,
"test '%s' failed (got %s expected %s" % (f,res,expected_res))
class testLocalRepositories(unittest.TestCase):
" test local repository regressions "
repo_dir = "local-repo"
apt = "apt-get"
pkg = "gdebi-test4"
def setUp(self):
self.repo = os.path.abspath(os.path.join(os.getcwd(), self.repo_dir))
self.sources = os.path.join(self.repo, "sources.list")
s = open(self.sources,"w")
s.write("deb file://%s/ /\n" % self.repo)
s.close()
def testLocalRepoAuth(self):
# two times to get at least one i-m-s hit
for i in range(2):
self.assert_(os.path.exists(self.sources))
cmd = [self.apt,"update","-o", "Dir::Etc::sourcelist=%s" % self.sources]+apt_args
res = call(cmd, stdout=stdout, stderr=stderr)
self.assertEqual(res, 0, "local repo test failed")
self.assert_(os.path.exists(os.path.join(self.repo,"Packages.gz")),
"Packages.gz vanished from local repo")
def testInstallFromLocalRepo(self):
apt = [self.apt,"-o", "Dir::Etc::sourcelist=%s"% self.sources]+apt_args
cmd = apt+["update"]
res = call(cmd, stdout=stdout, stderr=stderr)
self.assertEqual(res, 0)
res = call(apt+["-y","install","--reinstall",self.pkg],
stdout=stdout, stderr=stderr)
self.assert_(res == 0,
"installing %s failed (got %s)" % (self.pkg, res))
res = call(apt+["-y","remove",self.pkg],
stdout=stdout, stderr=stderr)
self.assert_(res == 0,
"removing %s failed (got %s)" % (self.pkg, res))
def testPythonAptInLocalRepo(self):
import apt, apt_pkg
apt_pkg.Config.Set("Dir::Etc::sourcelist",self.sources)
cache = apt.Cache()
cache.update()
pkg = cache["apt"]
self.assert_(pkg.name == 'apt')
if __name__ == "__main__":
print "Runing simple testsuit on current apt-get and libapt"
if len(sys.argv) > 1 and sys.argv[1] == "-v":
stdout = sys.stdout
stderr = sys.stderr
unittest.main()
|