| Age | Commit message (Collapse) | Author | 
|---|
|  |  | 
|  | Azure's ephemeral disks are not guaranteed to be assigned the same name by
the kernel every boot. This causes problems on ~2% of Azure instances, and
can be fixed by using udev rules to give us a deterministic path to mount;
this patch introduces those udev rules and modifies the Azure data source
to use them.
Changes to a couple of config modules were also required. In some places,
they just needed to learn to dereference symlinks. In cc_mounts this
wasn't sufficient because the dereferenced device would have been put in
/etc/fstab (rather defeating the point of using the udev rules in the
first place). A fairly hefty refactor was required to separate "is this a
valid block device?" from "what shall I put in fstab?".
LP: #1411582 | 
|  |  | 
|  | The ephemeral disk will not necessarily be assigned the same name at
each boot (LP: #1411582), so we use some udev rules to ensure we always
get the right one. | 
|  |  | 
|  |  | 
|  | Different versions of the CloudStack password server respond
differently; wget handles these nicely for us, so it's easier to just
use wget.
LP: #1440263, #1464253 | 
|  | The fabric provides the user password in plain text via the CDROM,
    and cloud-init has previously wrote the ovf-env.xml in /var/lib/waagent
    with the password in plain text. This change redacts the password. | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | Due to the way the azure boot works, where we identify the hostname to the
fabric, we were inadvertently overwriting hostname that the user had set.
LP: #1375252 | 
|  |  | 
|  |  | 
|  |  | 
|  | Including minor refactoring to make mocking considerably easier. | 
|  |  | 
|  | We are treating JoyentMetadataClient as a unit which the data source
depends on, so we mock it out instead of providing a fake implementation
of it. | 
|  |  | 
|  |  | 
|  |  | 
|  | HTTPretty can causes hangs on Python 3.4.2 (and maybe Python 3.4.1), due
to a Python bug (fixed in Python 3.4.3).  This works around the problem
in the appropriate Python versions.
See https://github.com/gabrielfalcao/HTTPretty/pull/193 and
https://github.com/gabrielfalcao/HTTPretty/issues/221 for details. | 
|  | UrlResponse: biggest change... make readurl return bytes, making user
             know what to do with it.
util: add load_tfile_or_url for loading text file or url
      as  read_file_or_url now returns bytes
ec2_utils: all meta-data is text, remove non-obvious string translations
DigitalOcean: adjust for ec2_utils
DataSourceGCE, DataSourceMAAS: user-data is binary other fields are text.
openstack.py: read paths without decoding to text.  This is ok as paths
              other than user-data are json, and load_json will handle
load_file still returns text, and that is what most things use. | 
|  | This was previously broken in python3 as the userdata would be bytes
rather than a string.
LP: #1423972 | 
|  | just seems to make more sense to decode here.
Add a test showing the previous failure (testBytesInPayload)
And one that should pass (testStringInPayload)
Also, add a test for unencoded content in the ovf xml (test_userdata_plain)
And explicitly set encoding on another test (test_userdata_found). | 
|  |  | 
|  |  | 
|  | This should fix the Azure data source on Python 3, and is appropriate as
XML shouldn't really be read as a string. | 
|  |  | 
|  | - Refactor both the base64 encoding and decoding into utility functions.
Also:
- Mechanically fix some other broken untested code. | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | * Temporarily skip the MAAS tests in py3 since they need to be ported to oauthlib. | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | might have to rewrite this for Python 2.6.
Disable Cepko tests (test_cs_util.py) since they are essentially worthless.
Convert test_azure to unittest.mock. | 
|  |  | 
|  | to be behind trunk.
`tox -e py27` passes full test suite.  Now to work on replacing mocker. |