4 # Copyright 2016 RIFT.IO Inc
6 # Licensed under the Apache License, Version 2.0 (the "License");
7 # you may not use this file except in compliance with the License.
8 # You may obtain a copy of the License at
10 # http://www.apache.org/licenses/LICENSE-2.0
12 # Unless required by applicable law or agreed to in writing, software
13 # distributed under the License is distributed on an "AS IS" BASIS,
14 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15 # See the License for the specific language governing permissions and
16 # limitations under the License.
30 gi
.require_version('RwDts', '1.0')
31 gi
.require_version('RwPkgMgmtYang', '1.0')
32 from gi
.repository
import (
36 import rift
.tasklets
.rwpkgmgr
.downloader
as downloader
37 import rift
.tasklets
.rwpkgmgr
.publisher
as pkg_publisher
41 class TestCase(rift
.test
.dts
.AbstractDTSTest
):
43 def configure_schema(cls
):
44 return RwPkgMgmtYang
.get_schema()
47 def configure_timeout(cls
):
50 def configure_test(self
, loop
, test_id
):
51 self
.log
.debug("STARTING - %s", test_id
)
52 self
.tinfo
= self
.new_tinfo(str(test_id
))
53 self
.dts
= rift
.tasklets
.DTS(self
.tinfo
, self
.schema
, self
.loop
)
55 self
.job_handler
= pkg_publisher
.DownloadStatusPublisher(self
.log
, self
.dts
, self
.loop
)
61 def get_published_xpaths(self
):
62 published_xpaths
= set()
64 res_iter
= yield from self
.dts
.query_read("D,/rwdts:dts")
66 res
= (yield from i
).result
67 for member
in res
.member
:
68 published_xpaths |
= {reg
.keyspec
for reg
in member
.state
.registration
if reg
.flags
== "publisher"}
70 return published_xpaths
73 def read_xpath(self
, xpath
):
74 itr
= yield from self
.dts
.query_read(xpath
)
78 result
= yield from fut
81 @rift.test
.dts
.async_test
82 def test_download_publisher(self
):
83 yield from self
.job_handler
.register()
84 published_xpaths
= yield from self
.get_published_xpaths()
85 assert self
.job_handler
.xpath() in published_xpaths
87 @rift.test
.dts
.async_test
88 def test_publish(self
):
91 1. Verify if an update on_download_progess & on_download_finished
93 2. Verify if the internal store is updated
95 yield from self
.job_handler
.register()
97 mock_msg
= RwPkgMgmtYang
.DownloadJob
.from_dict({
98 "url": "http://foo/bar",
100 "download_id": str(uuid
.uuid4())})
102 yield from self
.job_handler
._dts
_publisher
(mock_msg
)
103 yield from asyncio
.sleep(5, loop
=self
.loop
)
105 itr
= yield from self
.dts
.query_read("/download-jobs/job[download-id='{}']".format(
106 mock_msg
.download_id
))
110 result
= yield from fut
111 result
= result
.result
113 print ("Mock ", mock_msg
)
114 assert result
== mock_msg
117 mock_msg
.url
= "http://bar/foo"
118 yield from self
.job_handler
._dts
_publisher
(mock_msg
)
119 yield from asyncio
.sleep(5, loop
=self
.loop
)
121 itr
= yield from self
.dts
.query_read("/download-jobs/job[download-id='{}']".format(
122 mock_msg
.download_id
))
126 result
= yield from fut
127 result
= result
.result
128 assert result
== mock_msg
131 @rift.test
.dts
.async_test
132 def test_url_download(self
):
135 Test the updates with download/url.py
137 yield from self
.job_handler
.register()
139 proxy
= mock
.MagicMock()
141 url
= "http://boson.eng.riftio.com/common/unittests/plantuml.jar"
142 url_downloader
= downloader
.PackageFileDownloader(url
, "1", "/", "VNFD", "SCRIPTS", "VNF_CONFIG", proxy
)
144 download_id
= yield from self
.job_handler
.register_downloader(url_downloader
)
145 assert download_id
is not None
147 # Waiting for 5 secs to be sure that the file is downloaded
148 yield from asyncio
.sleep(10, loop
=self
.loop
)
149 xpath
= "/download-jobs/job[download-id='{}']".format(
151 result
= yield from self
.read_xpath(xpath
)
152 self
.log
.debug("Test result before complete check - %s", result
)
153 assert result
.status
== "COMPLETED"
154 assert len(self
.job_handler
.tasks
) == 0
156 @rift.test
.dts
.async_test
157 def test_url_download_unreachable_ip(self
):
160 Ensure that a bad IP does not block forever
162 yield from self
.job_handler
.register()
164 proxy
= mock
.MagicMock()
166 # Here, we are assuming that there is no HTTP server at 10.1.2.3
167 url
= "http://10.1.2.3/common/unittests/plantuml.jar"
168 url_downloader
= downloader
.PackageFileDownloader(url
, "1", "/", "VNFD", "SCRIPTS", "VNF_CONFIG", proxy
)
170 download_id
= yield from self
.job_handler
.register_downloader(url_downloader
)
171 assert download_id
is not None
173 # Waiting for 10 secs to be sure all reconnect attempts have been exhausted
174 yield from asyncio
.sleep(10, loop
=self
.loop
)
175 xpath
= "/download-jobs/job[download-id='{}']".format(
177 result
= yield from self
.read_xpath(xpath
)
178 self
.log
.debug("Test result before complete check - %s", result
)
179 assert result
.status
== "FAILED"
180 assert len(self
.job_handler
.tasks
) == 0
183 @rift.test
.dts
.async_test
184 def test_cancelled(self
):
187 1. Test the updates with downloader.py
188 2. Verifies if cancel triggers the job status to move to cancelled
190 yield from self
.job_handler
.register()
192 proxy
= mock
.MagicMock()
193 url
= "http://boson.eng.riftio.com/common/unittests/Fedora-x86_64-20-20131211.1-sda-ping.qcow2"
194 url_downloader
= downloader
.PackageFileDownloader(url
, "1", "/", "VNFD", "SCRIPTS", "VNF_CONFIG", proxy
)
196 download_id
= yield from self
.job_handler
.register_downloader(url_downloader
)
197 assert download_id
is not None
198 xpath
= "/download-jobs/job[download-id='{}']".format(
201 yield from asyncio
.sleep(1, loop
=self
.loop
)
203 result
= yield from self
.read_xpath(xpath
)
204 self
.log
.debug("Test result before in_progress check - %s", result
)
205 assert result
.status
== "IN_PROGRESS"
207 yield from self
.job_handler
.cancel_download(download_id
)
208 yield from asyncio
.sleep(3, loop
=self
.loop
)
209 result
= yield from self
.read_xpath(xpath
)
210 self
.log
.debug("Test result before cancel check - %s", result
)
211 assert result
.status
== "CANCELLED"
212 assert len(self
.job_handler
.tasks
) == 0
216 runner
= xmlrunner
.XMLTestRunner(output
=os
.environ
["RIFT_MODULE_TEST"])
218 parser
= argparse
.ArgumentParser()
219 parser
.add_argument('-v', '--verbose', action
='store_true')
220 parser
.add_argument('-n', '--no-runner', action
='store_true')
221 args
, unittest_args
= parser
.parse_known_args()
225 TestCase
.log_level
= logging
.DEBUG
if args
.verbose
else logging
.WARN
227 unittest
.main(testRunner
=runner
, argv
=[sys
.argv
[0]] + unittest_args
)
229 if __name__
== '__main__':