/usr/lib/python2.7/dist-packages/autopilot/content.py is in python-autopilot 1.4.1+15.10.20150911-0ubuntu2.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
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 | # -*- Mode: Python; coding: utf-8; indent-tabs-mode: nil; tab-width: 4 -*-
#
# Autopilot Functional Test Tool
# Copyright (C) 2013 Canonical
#
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# This program 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 General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>.
#
"""Content objects and helpers for autopilot tests."""
from __future__ import absolute_import
import io
import logging
from testtools.content import ContentType, content_from_stream, text_content
_logger = logging.getLogger(__name__)
def follow_file(path, test_case, content_name=None):
"""Start monitoring a file.
Use this convenience function to attach the contents of a file to a test.
:param path: The path to the file on disk you want to monitor.
:param test_case: An object that supports attaching details and cleanup
actions (i.e.- has the ``addDetail`` and ``addCleanup`` methods).
:param content_name: A name to give this content. If not specified, the
file path will be used instead.
"""
try:
file_obj = io.open(path, mode='rb')
except IOError as e:
_logger.error(
"Could not add content object '%s' due to IO Error: %s",
content_name,
str(e)
)
return text_content(u'')
else:
file_obj.seek(0, io.SEEK_END)
return follow_stream(
file_obj,
test_case,
content_name or file_obj.name
)
def follow_stream(stream, test_case, content_name):
"""Start monitoring the content from a stream.
This function can be used to attach a portion of a stream to a test.
:param stream: an open file-like object (that supports a read method that
returns bytes).
:param test_case: An object that supports attaching details and cleanup
actions (i.e.- has the ``addDetail`` and ``addCleanup`` methods).
:param content_name: A name to give this content. If not specified, the
file path will be used instead.
"""
def make_content():
content_obj = content_from_stream(
stream,
ContentType('text', 'plain', {'charset': 'iso8859-1'}),
buffer_now=True
)
test_case.addDetail(content_name, content_obj)
test_case.addCleanup(make_content)
|