def test_bind_existing_file(self): """ Tests binding a new repo when the underlying file exists and has repos in it (the existing repo shouldn't be deleted). """ # Setup repo_file = RepoFile(TEST_REPO_FILENAME) repo_file.add_repo(Repo('existing-repo-1')) repo_file.save() # Test url_list = ['http://pulpserver'] repolib.bind(TEST_REPO_FILENAME, TEST_MIRROR_LIST_FILENAME, TEST_KEYS_DIR, TEST_CERT_DIR, REPO_ID, REPO_NAME, url_list, {}, None, ENABLED, LOCK) # Verify self.assertTrue(os.path.exists(TEST_REPO_FILENAME)) repo_file = RepoFile(TEST_REPO_FILENAME) repo_file.load() self.assertEqual(2, len(repo_file.all_repos()))
def bind(repo_filename, mirror_list_filename, keys_root_dir, cert_root_dir, repo_id, repo_name, url_list, gpg_keys, clientcert, enabled, lock=None, verify_ssl=True, ca_path=DEFAULT_CA_PATH): """ Uses the given data to safely bind a repo to a repo file. This call will determine the best method for representing the repo given the data in the repo object as well as the list of URLs where the repo can be found. The default lock is defined at the module level and is used to ensure that concurrent access to the give files is prevented. Specific locks can be passed in for testing purposes to circumvent the default location of the lock which requires root access. :param repo_filename: full path to the location of the repo file in which the repo will be bound; this file does not need to exist prior to this call :type repo_filename: string :param mirror_list_filename: full path to the location of the mirror list file that should be written for the given repo if necessary; this should be unique for the given repo :type mirror_list_filename: string :param keys_root_dir: absolute path to the root directory in which the keys for all repos will be stored :type keys_root_dir: string :param cert_root_dir: absolute path to the root directory in which the certs for all repos will be stored :type cert_root_dir: string :param repo_id: uniquely identifies the repo being updated :type repo_id: string :param repo_name: the repo name :type repo_name: str :param url_list: list of URLs that will be used to access the repo; this call will determine the best way to represent the URL list in the repo definition :type url_list: list of strings :param gpg_keys: mapping of key name to contents for GPG keys to be used when verifying packages from this repo :type gpg_keys: dict {string: string} :param clientcert: The client certificate (PEM). :type clientcert: str :param enabled: Whether or not the repository is set to 'enabled' :type enabled: bool :param lock: if the default lock is unacceptble, it may be overridden in this variable :type lock: L{Lock} :param verify_ssl: Whether the repo file should be configured to validate CA trust. Defaults to True. :type verify_ssl: bool :param ca_path: Absolute path to a directory that contains trusted CA certificates. Defaults to pulp.bindings.server.DEFAULT_CA_PATH. :type ca_path: basestring """ if not lock: lock = Lock(LOCK_FILE) lock.acquire() try: log.info('Binding repo [%s]' % repo_id) repo_file = RepoFile(repo_filename) repo_file.load() # In the case of an update, only the changed values will have been sent. # Therefore, any of the major data components (repo data, url list, keys) # may be None. repo = repo_file.get_repo(repo_id) if not repo: # if no repo name is provided for a new repo, use the id for the name repo = Repo(repo_id) if repo_name is None: repo['name'] = repo_id else: repo['name'] = repo_name repo['enabled'] = str(int(enabled)) if repo_name: repo['name'] = repo_name if gpg_keys is not None: _handle_gpg_keys(repo, gpg_keys, keys_root_dir) _handle_client_cert(repo, cert_root_dir, clientcert) if verify_ssl: repo['sslverify'] = '1' repo['sslcacert'] = ca_path else: repo['sslverify'] = '0' if url_list is not None: _handle_host_urls(repo, url_list, mirror_list_filename) if repo_file.get_repo(repo.id): log.info('Updating existing repo [%s]' % repo.id) repo_file.update_repo(repo) else: log.info('Adding new repo [%s]' % repo.id) repo_file.add_repo(repo) repo_file.save() finally: lock.release()