Source code for stestr.commands.init

# 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.

"""Initialise a new repository."""

import errno
import sys

from cliff import command

from stestr.repository import util


[docs]class Init(command.Command): """Create a new repository."""
[docs] def take_action(self, parsed_args): init(self.app_args.repo_url)
[docs]def init(repo_url=None, stdout=sys.stdout): """Initialize a new repository This function will create initialize a new repostiory if one does not exist. If one exists the command will fail. Note this function depends on the cwd for the repository if `repo_url` is not specified it will use the repository located at CWD/.stestr :param str repo_url: The url of the repository to use. :return return_code: The exit code for the command. 0 for success and > 0 for failures. :rtype: int """ try: util.get_repo_initialise(repo_url=repo_url) except OSError as e: if e.errno != errno.EEXIST: raise repo_path = repo_url or './stestr' stdout.write('The specified repository directory %s already exists. ' 'Please check if the repository already exists or ' 'select a different path\n' % repo_path) return 1