Retire python-ganttclient
Change-Id: I642db1d24a26ac5b0d68cd91e7d7ec4156898270 Signed-off-by: Stephen Finucane <stephenfin@redhat.com>
This commit is contained in:
@@ -1,7 +0,0 @@
|
|||||||
[run]
|
|
||||||
branch = True
|
|
||||||
source = nova
|
|
||||||
omit = nova/tests/*,nova/openstack/*
|
|
||||||
|
|
||||||
[report]
|
|
||||||
ignore-errors = True
|
|
42
.gitignore
vendored
42
.gitignore
vendored
@@ -1,42 +0,0 @@
|
|||||||
*.DS_Store
|
|
||||||
*.egg*
|
|
||||||
*.log
|
|
||||||
*.mo
|
|
||||||
*.pyc
|
|
||||||
*.swo
|
|
||||||
*.swp
|
|
||||||
*.sqlite
|
|
||||||
*~
|
|
||||||
.autogenerated
|
|
||||||
.coverage
|
|
||||||
.nova-venv
|
|
||||||
.project
|
|
||||||
.pydevproject
|
|
||||||
.ropeproject
|
|
||||||
.testrepository/
|
|
||||||
.tox
|
|
||||||
.idea
|
|
||||||
.venv
|
|
||||||
AUTHORS
|
|
||||||
Authors
|
|
||||||
build-stamp
|
|
||||||
build/*
|
|
||||||
CA/
|
|
||||||
ChangeLog
|
|
||||||
coverage.xml
|
|
||||||
cover/*
|
|
||||||
covhtml
|
|
||||||
dist/*
|
|
||||||
doc/source/api/*
|
|
||||||
doc/build/*
|
|
||||||
instances
|
|
||||||
keeper
|
|
||||||
keys
|
|
||||||
local_settings.py
|
|
||||||
MANIFEST
|
|
||||||
nosetests.xml
|
|
||||||
nova/tests/cover/*
|
|
||||||
nova/vcsversion.py
|
|
||||||
tools/conf/nova.conf*
|
|
||||||
tools/lintstack.head.py
|
|
||||||
tools/pylint_exceptions
|
|
@@ -1,4 +1,4 @@
|
|||||||
[gerrit]
|
[gerrit]
|
||||||
host=review.openstack.org
|
host=review.openstack.org
|
||||||
port=29418
|
port=29418
|
||||||
project=openstack/nova.git
|
project=openstack/python-ganttclient.git
|
||||||
|
@@ -1,8 +0,0 @@
|
|||||||
[DEFAULT]
|
|
||||||
test_command=OS_STDOUT_CAPTURE=${OS_STDOUT_CAPTURE:-1} \
|
|
||||||
OS_STDERR_CAPTURE=${OS_STDERR_CAPTURE:-1} \
|
|
||||||
OS_TEST_TIMEOUT=${OS_TEST_TIMEOUT:-160} \
|
|
||||||
${PYTHON:-python} -m subunit.run discover -t ./ ./nova/tests $LISTOPT $IDOPTION
|
|
||||||
|
|
||||||
test_id_option=--load-list $IDFILE
|
|
||||||
test_list_option=--list
|
|
@@ -1,17 +0,0 @@
|
|||||||
If you would like to contribute to the development of OpenStack,
|
|
||||||
you must follow the steps in the "If you're a developer, start here"
|
|
||||||
section of this page:
|
|
||||||
|
|
||||||
http://wiki.openstack.org/HowToContribute
|
|
||||||
|
|
||||||
Once those steps have been completed, changes to OpenStack
|
|
||||||
should be submitted for review via the Gerrit tool, following
|
|
||||||
the workflow documented at:
|
|
||||||
|
|
||||||
http://wiki.openstack.org/GerritWorkflow
|
|
||||||
|
|
||||||
Pull requests submitted through GitHub will be ignored.
|
|
||||||
|
|
||||||
Bugs should be filed on Launchpad, not GitHub:
|
|
||||||
|
|
||||||
https://bugs.launchpad.net/nova
|
|
68
HACKING.rst
68
HACKING.rst
@@ -1,68 +0,0 @@
|
|||||||
Nova Style Commandments
|
|
||||||
=======================
|
|
||||||
|
|
||||||
- Step 1: Read the OpenStack Style Commandments
|
|
||||||
http://docs.openstack.org/developer/hacking/
|
|
||||||
- Step 2: Read on
|
|
||||||
|
|
||||||
Nova Specific Commandments
|
|
||||||
---------------------------
|
|
||||||
|
|
||||||
- ``nova.db`` imports are not allowed in ``nova/virt/*``
|
|
||||||
- [N309] no db session in public API methods (disabled)
|
|
||||||
This enforces a guideline defined in ``nova.openstack.common.db.sqlalchemy.session``
|
|
||||||
- [N310] timeutils.utcnow() wrapper must be used instead of direct calls to
|
|
||||||
datetime.datetime.utcnow() to make it easy to override its return value in tests
|
|
||||||
|
|
||||||
Creating Unit Tests
|
|
||||||
-------------------
|
|
||||||
For every new feature, unit tests should be created that both test and
|
|
||||||
(implicitly) document the usage of said feature. If submitting a patch for a
|
|
||||||
bug that had no unit test, a new passing unit test should be added. If a
|
|
||||||
submitted bug fix does have a unit test, be sure to add a new one that fails
|
|
||||||
without the patch and passes with the patch.
|
|
||||||
|
|
||||||
For more information on creating unit tests and utilizing the testing
|
|
||||||
infrastructure in OpenStack Nova, please read ``nova/tests/README.rst``.
|
|
||||||
|
|
||||||
|
|
||||||
Running Tests
|
|
||||||
-------------
|
|
||||||
The testing system is based on a combination of tox and testr. The canonical
|
|
||||||
approach to running tests is to simply run the command ``tox``. This will
|
|
||||||
create virtual environments, populate them with dependencies and run all of
|
|
||||||
the tests that OpenStack CI systems run. Behind the scenes, tox is running
|
|
||||||
``testr run --parallel``, but is set up such that you can supply any additional
|
|
||||||
testr arguments that are needed to tox. For example, you can run:
|
|
||||||
``tox -- --analyze-isolation`` to cause tox to tell testr to add
|
|
||||||
--analyze-isolation to its argument list.
|
|
||||||
|
|
||||||
It is also possible to run the tests inside of a virtual environment
|
|
||||||
you have created, or it is possible that you have all of the dependencies
|
|
||||||
installed locally already. In this case, you can interact with the testr
|
|
||||||
command directly. Running ``testr run`` will run the entire test suite. ``testr
|
|
||||||
run --parallel`` will run it in parallel (this is the default incantation tox
|
|
||||||
uses.) More information about testr can be found at:
|
|
||||||
http://wiki.openstack.org/testr
|
|
||||||
|
|
||||||
Building Docs
|
|
||||||
-------------
|
|
||||||
Normal Sphinx docs can be built via the setuptools ``build_sphinx`` command. To
|
|
||||||
do this via ``tox``, simply run ``tox -evenv -- python setup.py build_sphinx``,
|
|
||||||
which will cause a virtualenv with all of the needed dependencies to be
|
|
||||||
created and then inside of the virtualenv, the docs will be created and
|
|
||||||
put into doc/build/html.
|
|
||||||
|
|
||||||
If you'd like a PDF of the documentation, you'll need LaTeX installed, and
|
|
||||||
additionally some fonts. On Ubuntu systems, you can get what you need with::
|
|
||||||
|
|
||||||
apt-get install texlive-latex-recommended texlive-latex-extra texlive-fonts-recommended
|
|
||||||
|
|
||||||
Then run ``build_sphinx_latex``, change to the build dir and run ``make``.
|
|
||||||
Like so::
|
|
||||||
|
|
||||||
tox -evenv -- python setup.py build_sphinx_latex
|
|
||||||
cd build/sphinx/latex
|
|
||||||
make
|
|
||||||
|
|
||||||
You should wind up with a PDF - Nova.pdf.
|
|
176
LICENSE
176
LICENSE
@@ -1,176 +0,0 @@
|
|||||||
|
|
||||||
Apache License
|
|
||||||
Version 2.0, January 2004
|
|
||||||
http://www.apache.org/licenses/
|
|
||||||
|
|
||||||
TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
|
|
||||||
|
|
||||||
1. Definitions.
|
|
||||||
|
|
||||||
"License" shall mean the terms and conditions for use, reproduction,
|
|
||||||
and distribution as defined by Sections 1 through 9 of this document.
|
|
||||||
|
|
||||||
"Licensor" shall mean the copyright owner or entity authorized by
|
|
||||||
the copyright owner that is granting the License.
|
|
||||||
|
|
||||||
"Legal Entity" shall mean the union of the acting entity and all
|
|
||||||
other entities that control, are controlled by, or are under common
|
|
||||||
control with that entity. For the purposes of this definition,
|
|
||||||
"control" means (i) the power, direct or indirect, to cause the
|
|
||||||
direction or management of such entity, whether by contract or
|
|
||||||
otherwise, or (ii) ownership of fifty percent (50%) or more of the
|
|
||||||
outstanding shares, or (iii) beneficial ownership of such entity.
|
|
||||||
|
|
||||||
"You" (or "Your") shall mean an individual or Legal Entity
|
|
||||||
exercising permissions granted by this License.
|
|
||||||
|
|
||||||
"Source" form shall mean the preferred form for making modifications,
|
|
||||||
including but not limited to software source code, documentation
|
|
||||||
source, and configuration files.
|
|
||||||
|
|
||||||
"Object" form shall mean any form resulting from mechanical
|
|
||||||
transformation or translation of a Source form, including but
|
|
||||||
not limited to compiled object code, generated documentation,
|
|
||||||
and conversions to other media types.
|
|
||||||
|
|
||||||
"Work" shall mean the work of authorship, whether in Source or
|
|
||||||
Object form, made available under the License, as indicated by a
|
|
||||||
copyright notice that is included in or attached to the work
|
|
||||||
(an example is provided in the Appendix below).
|
|
||||||
|
|
||||||
"Derivative Works" shall mean any work, whether in Source or Object
|
|
||||||
form, that is based on (or derived from) the Work and for which the
|
|
||||||
editorial revisions, annotations, elaborations, or other modifications
|
|
||||||
represent, as a whole, an original work of authorship. For the purposes
|
|
||||||
of this License, Derivative Works shall not include works that remain
|
|
||||||
separable from, or merely link (or bind by name) to the interfaces of,
|
|
||||||
the Work and Derivative Works thereof.
|
|
||||||
|
|
||||||
"Contribution" shall mean any work of authorship, including
|
|
||||||
the original version of the Work and any modifications or additions
|
|
||||||
to that Work or Derivative Works thereof, that is intentionally
|
|
||||||
submitted to Licensor for inclusion in the Work by the copyright owner
|
|
||||||
or by an individual or Legal Entity authorized to submit on behalf of
|
|
||||||
the copyright owner. For the purposes of this definition, "submitted"
|
|
||||||
means any form of electronic, verbal, or written communication sent
|
|
||||||
to the Licensor or its representatives, including but not limited to
|
|
||||||
communication on electronic mailing lists, source code control systems,
|
|
||||||
and issue tracking systems that are managed by, or on behalf of, the
|
|
||||||
Licensor for the purpose of discussing and improving the Work, but
|
|
||||||
excluding communication that is conspicuously marked or otherwise
|
|
||||||
designated in writing by the copyright owner as "Not a Contribution."
|
|
||||||
|
|
||||||
"Contributor" shall mean Licensor and any individual or Legal Entity
|
|
||||||
on behalf of whom a Contribution has been received by Licensor and
|
|
||||||
subsequently incorporated within the Work.
|
|
||||||
|
|
||||||
2. Grant of Copyright License. Subject to the terms and conditions of
|
|
||||||
this License, each Contributor hereby grants to You a perpetual,
|
|
||||||
worldwide, non-exclusive, no-charge, royalty-free, irrevocable
|
|
||||||
copyright license to reproduce, prepare Derivative Works of,
|
|
||||||
publicly display, publicly perform, sublicense, and distribute the
|
|
||||||
Work and such Derivative Works in Source or Object form.
|
|
||||||
|
|
||||||
3. Grant of Patent License. Subject to the terms and conditions of
|
|
||||||
this License, each Contributor hereby grants to You a perpetual,
|
|
||||||
worldwide, non-exclusive, no-charge, royalty-free, irrevocable
|
|
||||||
(except as stated in this section) patent license to make, have made,
|
|
||||||
use, offer to sell, sell, import, and otherwise transfer the Work,
|
|
||||||
where such license applies only to those patent claims licensable
|
|
||||||
by such Contributor that are necessarily infringed by their
|
|
||||||
Contribution(s) alone or by combination of their Contribution(s)
|
|
||||||
with the Work to which such Contribution(s) was submitted. If You
|
|
||||||
institute patent litigation against any entity (including a
|
|
||||||
cross-claim or counterclaim in a lawsuit) alleging that the Work
|
|
||||||
or a Contribution incorporated within the Work constitutes direct
|
|
||||||
or contributory patent infringement, then any patent licenses
|
|
||||||
granted to You under this License for that Work shall terminate
|
|
||||||
as of the date such litigation is filed.
|
|
||||||
|
|
||||||
4. Redistribution. You may reproduce and distribute copies of the
|
|
||||||
Work or Derivative Works thereof in any medium, with or without
|
|
||||||
modifications, and in Source or Object form, provided that You
|
|
||||||
meet the following conditions:
|
|
||||||
|
|
||||||
(a) You must give any other recipients of the Work or
|
|
||||||
Derivative Works a copy of this License; and
|
|
||||||
|
|
||||||
(b) You must cause any modified files to carry prominent notices
|
|
||||||
stating that You changed the files; and
|
|
||||||
|
|
||||||
(c) You must retain, in the Source form of any Derivative Works
|
|
||||||
that You distribute, all copyright, patent, trademark, and
|
|
||||||
attribution notices from the Source form of the Work,
|
|
||||||
excluding those notices that do not pertain to any part of
|
|
||||||
the Derivative Works; and
|
|
||||||
|
|
||||||
(d) If the Work includes a "NOTICE" text file as part of its
|
|
||||||
distribution, then any Derivative Works that You distribute must
|
|
||||||
include a readable copy of the attribution notices contained
|
|
||||||
within such NOTICE file, excluding those notices that do not
|
|
||||||
pertain to any part of the Derivative Works, in at least one
|
|
||||||
of the following places: within a NOTICE text file distributed
|
|
||||||
as part of the Derivative Works; within the Source form or
|
|
||||||
documentation, if provided along with the Derivative Works; or,
|
|
||||||
within a display generated by the Derivative Works, if and
|
|
||||||
wherever such third-party notices normally appear. The contents
|
|
||||||
of the NOTICE file are for informational purposes only and
|
|
||||||
do not modify the License. You may add Your own attribution
|
|
||||||
notices within Derivative Works that You distribute, alongside
|
|
||||||
or as an addendum to the NOTICE text from the Work, provided
|
|
||||||
that such additional attribution notices cannot be construed
|
|
||||||
as modifying the License.
|
|
||||||
|
|
||||||
You may add Your own copyright statement to Your modifications and
|
|
||||||
may provide additional or different license terms and conditions
|
|
||||||
for use, reproduction, or distribution of Your modifications, or
|
|
||||||
for any such Derivative Works as a whole, provided Your use,
|
|
||||||
reproduction, and distribution of the Work otherwise complies with
|
|
||||||
the conditions stated in this License.
|
|
||||||
|
|
||||||
5. Submission of Contributions. Unless You explicitly state otherwise,
|
|
||||||
any Contribution intentionally submitted for inclusion in the Work
|
|
||||||
by You to the Licensor shall be under the terms and conditions of
|
|
||||||
this License, without any additional terms or conditions.
|
|
||||||
Notwithstanding the above, nothing herein shall supersede or modify
|
|
||||||
the terms of any separate license agreement you may have executed
|
|
||||||
with Licensor regarding such Contributions.
|
|
||||||
|
|
||||||
6. Trademarks. This License does not grant permission to use the trade
|
|
||||||
names, trademarks, service marks, or product names of the Licensor,
|
|
||||||
except as required for reasonable and customary use in describing the
|
|
||||||
origin of the Work and reproducing the content of the NOTICE file.
|
|
||||||
|
|
||||||
7. Disclaimer of Warranty. Unless required by applicable law or
|
|
||||||
agreed to in writing, Licensor provides the Work (and each
|
|
||||||
Contributor provides its Contributions) on an "AS IS" BASIS,
|
|
||||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
|
|
||||||
implied, including, without limitation, any warranties or conditions
|
|
||||||
of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A
|
|
||||||
PARTICULAR PURPOSE. You are solely responsible for determining the
|
|
||||||
appropriateness of using or redistributing the Work and assume any
|
|
||||||
risks associated with Your exercise of permissions under this License.
|
|
||||||
|
|
||||||
8. Limitation of Liability. In no event and under no legal theory,
|
|
||||||
whether in tort (including negligence), contract, or otherwise,
|
|
||||||
unless required by applicable law (such as deliberate and grossly
|
|
||||||
negligent acts) or agreed to in writing, shall any Contributor be
|
|
||||||
liable to You for damages, including any direct, indirect, special,
|
|
||||||
incidental, or consequential damages of any character arising as a
|
|
||||||
result of this License or out of the use or inability to use the
|
|
||||||
Work (including but not limited to damages for loss of goodwill,
|
|
||||||
work stoppage, computer failure or malfunction, or any and all
|
|
||||||
other commercial damages or losses), even if such Contributor
|
|
||||||
has been advised of the possibility of such damages.
|
|
||||||
|
|
||||||
9. Accepting Warranty or Additional Liability. While redistributing
|
|
||||||
the Work or Derivative Works thereof, You may choose to offer,
|
|
||||||
and charge a fee for, acceptance of support, warranty, indemnity,
|
|
||||||
or other liability obligations and/or rights consistent with this
|
|
||||||
License. However, in accepting such obligations, You may act only
|
|
||||||
on Your own behalf and on Your sole responsibility, not on behalf
|
|
||||||
of any other Contributor, and only if You agree to indemnify,
|
|
||||||
defend, and hold each Contributor harmless for any liability
|
|
||||||
incurred by, or claims asserted against, such Contributor by reason
|
|
||||||
of your accepting any such warranty or additional liability.
|
|
||||||
|
|
@@ -1,6 +0,0 @@
|
|||||||
include AUTHORS
|
|
||||||
include ChangeLog
|
|
||||||
exclude .gitignore
|
|
||||||
exclude .gitreview
|
|
||||||
|
|
||||||
global-exclude *.pyc
|
|
9
README
Normal file
9
README
Normal file
@@ -0,0 +1,9 @@
|
|||||||
|
This project is no longer maintained.
|
||||||
|
|
||||||
|
The contents of this repository are still available in the Git
|
||||||
|
source code management system. To see the contents of this
|
||||||
|
repository before it reached its end of life, please check out the
|
||||||
|
previous commit with "git checkout HEAD^1".
|
||||||
|
|
||||||
|
For any further questions, please email
|
||||||
|
openstack-discuss@lists.openstack.org.
|
61
README.rst
61
README.rst
@@ -1,61 +0,0 @@
|
|||||||
OpenStack Nova README
|
|
||||||
=====================
|
|
||||||
|
|
||||||
OpenStack Nova provides a cloud computing fabric controller,
|
|
||||||
supporting a wide variety of virtualization technologies,
|
|
||||||
including KVM, Xen, LXC, VMware, and more. In addition to
|
|
||||||
its native API, it includes compatibility with the commonly
|
|
||||||
encountered Amazon EC2 and S3 APIs.
|
|
||||||
|
|
||||||
OpenStack Nova is distributed under the terms of the Apache
|
|
||||||
License, Version 2.0. The full terms and conditions of this
|
|
||||||
license are detailed in the LICENSE file.
|
|
||||||
|
|
||||||
Nova primarily consists of a set of Python daemons, though
|
|
||||||
it requires and integrates with a number of native system
|
|
||||||
components for databases, messaging and virtualization
|
|
||||||
capabilities.
|
|
||||||
|
|
||||||
To keep updated with new developments in the OpenStack project
|
|
||||||
follow `@openstack <http://twitter.com/openstack>`_ on Twitter.
|
|
||||||
|
|
||||||
To learn how to deploy OpenStack Nova, consult the documentation
|
|
||||||
available online at:
|
|
||||||
|
|
||||||
http://docs.openstack.org
|
|
||||||
|
|
||||||
For information about the different compute (hypervisor) drivers
|
|
||||||
supported by Nova, read this page on the wiki:
|
|
||||||
|
|
||||||
https://wiki.openstack.org/wiki/HypervisorSupportMatrix
|
|
||||||
|
|
||||||
In the unfortunate event that bugs are discovered, they should
|
|
||||||
be reported to the appropriate bug tracker. If you obtained
|
|
||||||
the software from a 3rd party operating system vendor, it is
|
|
||||||
often wise to use their own bug tracker for reporting problems.
|
|
||||||
In all other cases use the master OpenStack bug tracker,
|
|
||||||
available at:
|
|
||||||
|
|
||||||
http://bugs.launchpad.net/nova
|
|
||||||
|
|
||||||
Developers wishing to work on the OpenStack Nova project should
|
|
||||||
always base their work on the latest Nova code, available from
|
|
||||||
the master GIT repository at:
|
|
||||||
|
|
||||||
http://github.com/openstack/nova
|
|
||||||
|
|
||||||
Developers should also join the discussion on the mailing list,
|
|
||||||
at:
|
|
||||||
|
|
||||||
http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack
|
|
||||||
|
|
||||||
Any new code must follow the development guidelines detailed
|
|
||||||
in the HACKING.rst file, and pass all unit tests. Further
|
|
||||||
developer focused documentation is available at:
|
|
||||||
|
|
||||||
http://nova.openstack.org/
|
|
||||||
|
|
||||||
For information on how to contribute to Nova, please see the
|
|
||||||
contents of the CONTRIBUTING.rst file.
|
|
||||||
|
|
||||||
-- End of broadcast
|
|
@@ -1,27 +0,0 @@
|
|||||||
# vim: tabstop=4 shiftwidth=4 softtabstop=4
|
|
||||||
|
|
||||||
# Copyright (c) 2010 OpenStack Foundation
|
|
||||||
#
|
|
||||||
# Licensed under the Apache License, Version 2.0 (the "License"); you may
|
|
||||||
# not use this file except in compliance with the License. You may obtain
|
|
||||||
# a copy of the License at
|
|
||||||
#
|
|
||||||
# http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
#
|
|
||||||
# Unless required by applicable law or agreed to in writing, software
|
|
||||||
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
||||||
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
||||||
# License for the specific language governing permissions and limitations
|
|
||||||
# under the License.
|
|
||||||
|
|
||||||
"""
|
|
||||||
:mod:`nova.scheduler` -- Scheduler Nodes
|
|
||||||
=====================================================
|
|
||||||
|
|
||||||
.. automodule:: nova.scheduler
|
|
||||||
:platform: Unix
|
|
||||||
:synopsis: Module that picks a compute node to run a VM instance.
|
|
||||||
.. moduleauthor:: Sandy Walsh <sandy.walsh@rackspace.com>
|
|
||||||
.. moduleauthor:: Ed Leafe <ed@leafe.com>
|
|
||||||
.. moduleauthor:: Chris Behrens <cbehrens@codestud.com>
|
|
||||||
"""
|
|
@@ -1,142 +0,0 @@
|
|||||||
# vim: tabstop=4 shiftwidth=4 softtabstop=4
|
|
||||||
|
|
||||||
# Copyright 2012, Red Hat, Inc.
|
|
||||||
#
|
|
||||||
# Licensed under the Apache License, Version 2.0 (the "License"); you may
|
|
||||||
# not use this file except in compliance with the License. You may obtain
|
|
||||||
# a copy of the License at
|
|
||||||
#
|
|
||||||
# http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
#
|
|
||||||
# Unless required by applicable law or agreed to in writing, software
|
|
||||||
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
||||||
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
||||||
# License for the specific language governing permissions and limitations
|
|
||||||
# under the License.
|
|
||||||
|
|
||||||
"""
|
|
||||||
Client side of the scheduler manager RPC API.
|
|
||||||
"""
|
|
||||||
|
|
||||||
from oslo.config import cfg
|
|
||||||
|
|
||||||
from nova.openstack.common import jsonutils
|
|
||||||
from nova import rpcclient
|
|
||||||
|
|
||||||
rpcapi_opts = [
|
|
||||||
cfg.StrOpt('scheduler_topic',
|
|
||||||
default='scheduler',
|
|
||||||
help='the topic scheduler nodes listen on'),
|
|
||||||
]
|
|
||||||
|
|
||||||
CONF = cfg.CONF
|
|
||||||
CONF.register_opts(rpcapi_opts)
|
|
||||||
|
|
||||||
rpcapi_cap_opt = cfg.StrOpt('scheduler',
|
|
||||||
help='Set a version cap for messages sent to scheduler services')
|
|
||||||
CONF.register_opt(rpcapi_cap_opt, 'upgrade_levels')
|
|
||||||
|
|
||||||
|
|
||||||
class SchedulerAPI(rpcclient.RpcProxy):
|
|
||||||
'''Client side of the scheduler rpc API.
|
|
||||||
|
|
||||||
API version history:
|
|
||||||
|
|
||||||
1.0 - Initial version.
|
|
||||||
1.1 - Changes to prep_resize():
|
|
||||||
- remove instance_uuid, add instance
|
|
||||||
- remove instance_type_id, add instance_type
|
|
||||||
- remove topic, it was unused
|
|
||||||
1.2 - Remove topic from run_instance, it was unused
|
|
||||||
1.3 - Remove instance_id, add instance to live_migration
|
|
||||||
1.4 - Remove update_db from prep_resize
|
|
||||||
1.5 - Add reservations argument to prep_resize()
|
|
||||||
1.6 - Remove reservations argument to run_instance()
|
|
||||||
1.7 - Add create_volume() method, remove topic from live_migration()
|
|
||||||
|
|
||||||
2.0 - Remove 1.x backwards compat
|
|
||||||
2.1 - Add image_id to create_volume()
|
|
||||||
2.2 - Remove reservations argument to create_volume()
|
|
||||||
2.3 - Remove create_volume()
|
|
||||||
2.4 - Change update_service_capabilities()
|
|
||||||
- accepts a list of capabilities
|
|
||||||
2.5 - Add get_backdoor_port()
|
|
||||||
2.6 - Add select_hosts()
|
|
||||||
|
|
||||||
... Grizzly supports message version 2.6. So, any changes to existing
|
|
||||||
methods in 2.x after that point should be done such that they can
|
|
||||||
handle the version_cap being set to 2.6.
|
|
||||||
|
|
||||||
2.7 - Add select_destinations()
|
|
||||||
2.8 - Deprecate prep_resize() -- JUST KIDDING. It is still used
|
|
||||||
by the compute manager for retries.
|
|
||||||
2.9 - Added the legacy_bdm_in_spec parameter to run_instance()
|
|
||||||
|
|
||||||
... Havana supports message version 2.9. So, any changes to existing
|
|
||||||
methods in 2.x after that point should be done such that they can
|
|
||||||
handle the version_cap being set to 2.9.
|
|
||||||
|
|
||||||
... - Deprecated live_migration() call, moved to conductor
|
|
||||||
'''
|
|
||||||
|
|
||||||
#
|
|
||||||
# NOTE(russellb): This is the default minimum version that the server
|
|
||||||
# (manager) side must implement unless otherwise specified using a version
|
|
||||||
# argument to self.call()/cast()/etc. here. It should be left as X.0 where
|
|
||||||
# X is the current major API version (1.0, 2.0, ...). For more information
|
|
||||||
# about rpc API versioning, see the docs in
|
|
||||||
# openstack/common/rpc/dispatcher.py.
|
|
||||||
#
|
|
||||||
BASE_RPC_API_VERSION = '2.0'
|
|
||||||
|
|
||||||
VERSION_ALIASES = {
|
|
||||||
'grizzly': '2.6',
|
|
||||||
'havana': '2.9',
|
|
||||||
}
|
|
||||||
|
|
||||||
def __init__(self):
|
|
||||||
version_cap = self.VERSION_ALIASES.get(CONF.upgrade_levels.scheduler,
|
|
||||||
CONF.upgrade_levels.scheduler)
|
|
||||||
super(SchedulerAPI, self).__init__(topic=CONF.scheduler_topic,
|
|
||||||
default_version=self.BASE_RPC_API_VERSION,
|
|
||||||
version_cap=version_cap)
|
|
||||||
self.client = self.get_client()
|
|
||||||
|
|
||||||
def select_destinations(self, ctxt, request_spec, filter_properties):
|
|
||||||
cctxt = self.client.prepare(version='2.7')
|
|
||||||
return cctxt.call(ctxt, 'select_destinations',
|
|
||||||
request_spec=request_spec, filter_properties=filter_properties)
|
|
||||||
|
|
||||||
def run_instance(self, ctxt, request_spec, admin_password,
|
|
||||||
injected_files, requested_networks, is_first_time,
|
|
||||||
filter_properties, legacy_bdm_in_spec=True):
|
|
||||||
version = '2.0'
|
|
||||||
msg_kwargs = {'request_spec': request_spec,
|
|
||||||
'admin_password': admin_password,
|
|
||||||
'injected_files': injected_files,
|
|
||||||
'requested_networks': requested_networks,
|
|
||||||
'is_first_time': is_first_time,
|
|
||||||
'filter_properties': filter_properties}
|
|
||||||
if self.client.can_send_version('2.9'):
|
|
||||||
version = '2.9'
|
|
||||||
msg_kwargs['legacy_bdm_in_spec'] = legacy_bdm_in_spec
|
|
||||||
cctxt = self.client.prepare(version=version)
|
|
||||||
return cctxt.cast(ctxt, 'run_instance', **msg_kwargs)
|
|
||||||
|
|
||||||
def prep_resize(self, ctxt, instance, instance_type, image,
|
|
||||||
request_spec, filter_properties, reservations):
|
|
||||||
instance_p = jsonutils.to_primitive(instance)
|
|
||||||
instance_type_p = jsonutils.to_primitive(instance_type)
|
|
||||||
reservations_p = jsonutils.to_primitive(reservations)
|
|
||||||
image_p = jsonutils.to_primitive(image)
|
|
||||||
self.client.cast(ctxt, 'prep_resize',
|
|
||||||
instance=instance_p, instance_type=instance_type_p,
|
|
||||||
image=image_p, request_spec=request_spec,
|
|
||||||
filter_properties=filter_properties,
|
|
||||||
reservations=reservations_p)
|
|
||||||
|
|
||||||
def select_hosts(self, ctxt, request_spec, filter_properties):
|
|
||||||
cctxt = self.client.prepare(version='2.6')
|
|
||||||
return cctxt.call(ctxt, 'select_hosts',
|
|
||||||
request_spec=request_spec,
|
|
||||||
filter_properties=filter_properties)
|
|
@@ -1,16 +0,0 @@
|
|||||||
# vim: tabstop=4 shiftwidth=4 softtabstop=4
|
|
||||||
|
|
||||||
# Copyright 2011 OpenStack Foundation
|
|
||||||
# All Rights Reserved.
|
|
||||||
#
|
|
||||||
# Licensed under the Apache License, Version 2.0 (the "License"); you may
|
|
||||||
# not use this file except in compliance with the License. You may obtain
|
|
||||||
# a copy of the License at
|
|
||||||
#
|
|
||||||
# http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
#
|
|
||||||
# Unless required by applicable law or agreed to in writing, software
|
|
||||||
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
||||||
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
||||||
# License for the specific language governing permissions and limitations
|
|
||||||
# under the License.
|
|
@@ -1,83 +0,0 @@
|
|||||||
# vim: tabstop=4 shiftwidth=4 softtabstop=4
|
|
||||||
|
|
||||||
# Copyright 2012, Red Hat, Inc.
|
|
||||||
#
|
|
||||||
# Licensed under the Apache License, Version 2.0 (the "License"); you may
|
|
||||||
# not use this file except in compliance with the License. You may obtain
|
|
||||||
# a copy of the License at
|
|
||||||
#
|
|
||||||
# http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
#
|
|
||||||
# Unless required by applicable law or agreed to in writing, software
|
|
||||||
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
||||||
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
||||||
# License for the specific language governing permissions and limitations
|
|
||||||
# under the License.
|
|
||||||
|
|
||||||
"""
|
|
||||||
Unit Tests for nova.scheduler.rpcapi
|
|
||||||
"""
|
|
||||||
|
|
||||||
from oslo.config import cfg
|
|
||||||
|
|
||||||
from nova import context
|
|
||||||
from nova.openstack.common import rpc
|
|
||||||
from nova.scheduler import rpcapi as scheduler_rpcapi
|
|
||||||
from nova import test
|
|
||||||
|
|
||||||
CONF = cfg.CONF
|
|
||||||
|
|
||||||
|
|
||||||
class SchedulerRpcAPITestCase(test.NoDBTestCase):
|
|
||||||
def _test_scheduler_api(self, method, rpc_method, **kwargs):
|
|
||||||
ctxt = context.RequestContext('fake_user', 'fake_project')
|
|
||||||
rpcapi = scheduler_rpcapi.SchedulerAPI()
|
|
||||||
expected_retval = 'foo' if method == 'call' else None
|
|
||||||
expected_version = kwargs.pop('version', rpcapi.BASE_RPC_API_VERSION)
|
|
||||||
expected_msg = rpcapi.make_msg(method, **kwargs)
|
|
||||||
expected_msg['version'] = expected_version
|
|
||||||
|
|
||||||
self.fake_args = None
|
|
||||||
self.fake_kwargs = None
|
|
||||||
|
|
||||||
def _fake_rpc_method(*args, **kwargs):
|
|
||||||
self.fake_args = args
|
|
||||||
self.fake_kwargs = kwargs
|
|
||||||
if expected_retval:
|
|
||||||
return expected_retval
|
|
||||||
|
|
||||||
self.stubs.Set(rpc, rpc_method, _fake_rpc_method)
|
|
||||||
|
|
||||||
retval = getattr(rpcapi, method)(ctxt, **kwargs)
|
|
||||||
|
|
||||||
self.assertEqual(retval, expected_retval)
|
|
||||||
expected_args = [ctxt, CONF.scheduler_topic, expected_msg]
|
|
||||||
for arg, expected_arg in zip(self.fake_args, expected_args):
|
|
||||||
self.assertEqual(arg, expected_arg)
|
|
||||||
|
|
||||||
def test_run_instance(self):
|
|
||||||
self._test_scheduler_api('run_instance', rpc_method='cast',
|
|
||||||
request_spec='fake_request_spec',
|
|
||||||
admin_password='pw', injected_files='fake_injected_files',
|
|
||||||
requested_networks='fake_requested_networks',
|
|
||||||
is_first_time=True, filter_properties='fake_filter_properties',
|
|
||||||
legacy_bdm_in_spec=False, version='2.9')
|
|
||||||
|
|
||||||
def test_prep_resize(self):
|
|
||||||
self._test_scheduler_api('prep_resize', rpc_method='cast',
|
|
||||||
instance='fake_instance',
|
|
||||||
instance_type='fake_type', image='fake_image',
|
|
||||||
request_spec='fake_request_spec',
|
|
||||||
filter_properties='fake_props', reservations=list('fake_res'))
|
|
||||||
|
|
||||||
def test_select_hosts(self):
|
|
||||||
self._test_scheduler_api('select_hosts', rpc_method='call',
|
|
||||||
request_spec='fake_request_spec',
|
|
||||||
filter_properties='fake_prop',
|
|
||||||
version='2.6')
|
|
||||||
|
|
||||||
def test_select_destinations(self):
|
|
||||||
self._test_scheduler_api('select_destinations', rpc_method='call',
|
|
||||||
request_spec='fake_request_spec',
|
|
||||||
filter_properties='fake_prop',
|
|
||||||
version='2.7')
|
|
Reference in New Issue
Block a user