diff --git a/bin/aptly-cli b/bin/aptly-cli index 001ba4f..afa723a 100755 --- a/bin/aptly-cli +++ b/bin/aptly-cli @@ -8,6 +8,44 @@ require 'aptly_cli' program :version, AptlyCli::VERSION program :description, 'Aptly repository API client' +$config_file = '/etc/aptly-cli.conf' +$server = nil +$username = nil +$password = nil +$debug = false + +global_option('-c', '--config FILE', 'Path to YAML config file') do |config_file| + $config_file = config_file +end + +global_option('-s', '--server SERVER', 'Host name or IP address') do |server| + $server = server +end +global_option('--username USERNAME', 'User name') do |username| + $username = username +end +global_option('--password PASSWORD', 'Password') do |password| + $password = password +end +global_option('--debug', 'Enable debug output') do + $debug = true +end + +def handle_global_options(options) + if $server + options.server = $server + end + if $username + options.username = $username + end + if $password + options.password = $password + end + if $debug + options.debug = $debug + end +end + command :file_list do |c| c.syntax = 'aptly-cli file_list [options]' c.summary = 'List all directories' @@ -15,7 +53,9 @@ command :file_list do |c| c.example 'List all directories for file uploads', 'aptly-cli file_list' c.option '--directory DIRECTORY', String, 'Directory to list packages on server' c.action do |args, options| - aptly_command = AptlyCli::AptlyFile.new + config = AptlyCli::AptlyLoad.new.configure_with($config_file) + handle_global_options options + aptly_command = AptlyCli::AptlyFile.new(config, options) if options.directory puts aptly_command.file_get(options.directory) else @@ -32,7 +72,9 @@ command :file_upload do |c| c.option '--directory DIRECTORY', String, 'Directory to load packages into' c.option '--upload UPLOAD', String, 'Package(s) to upload' c.action do |args, options| - aptly_command = AptlyCli::AptlyFile.new + config = AptlyCli::AptlyLoad.new.configure_with($config_file) + handle_global_options options + aptly_command = AptlyCli::AptlyFile.new(config, options) puts aptly_command.file_post(:file_uri => options.directory, :package => options.upload, :local_file => options.upload) end end @@ -46,7 +88,9 @@ command :file_delete do |c| 'aptly-cli file_delete --target /redis/redis-server_2.8.3_i386-cc1.deb') c.option '--target TARGET', String, 'Path to directory or specific package to delete' c.action do |args, options| - aptly_command = AptlyCli::AptlyFile.new + config = AptlyCli::AptlyLoad.new.configure_with($config_file) + handle_global_options options + aptly_command = AptlyCli::AptlyFile.new(config, options) puts aptly_command.file_delete(options.target) end end @@ -63,7 +107,9 @@ command :repo_create do |c| c.option '--default_component COMPONENT', String, 'Default component when publishing from this local repo' c.action do |args, options| puts options.name - aptly_command = AptlyCli::AptlyRepo.new + config = AptlyCli::AptlyLoad.new.configure_with($config_file) + handle_global_options options + aptly_command = AptlyCli::AptlyRepo.new(config, options) repo_options = { :name => options.name.to_s, :comment => options.comment.to_s, :DefaultDistribution => options.default_distribution.to_s, @@ -80,7 +126,9 @@ command :repo_delete do |c| c.option '--name NAME', String, 'Local repository name, required' c.option '--force' c.action do |args, options| - aptly_command = AptlyCli::AptlyRepo.new + config = AptlyCli::AptlyLoad.new.configure_with($config_file) + handle_global_options options + aptly_command = AptlyCli::AptlyRepo.new(config, options) repo_options = { :name => options.name.to_s, :force => options.force.to_s } puts aptly_command.repo_delete(repo_options) @@ -97,7 +145,9 @@ command :repo_edit do |c| c.option '--default_distribution DISTRIBUTION', String, 'Edit DefaultDistribution for repo' c.option '--default_component COMPONENT', String, 'Edit DefaultComponent for repo' c.action do |args, options| - aptly_command = AptlyCli::AptlyRepo.new + config = AptlyCli::AptlyLoad.new.configure_with($config_file) + handle_global_options options + aptly_command = AptlyCli::AptlyRepo.new(config, options) if options.default_distribution repo_options = { :DefaultDistribution => options.default_distribution.to_s } end @@ -117,7 +167,9 @@ command :repo_list do |c| c.description = 'Show list of currently available local repositories' c.example 'description', 'aptly-cli repo_list' c.action do |args, options| - aptly_command = AptlyCli::AptlyRepo.new + config = AptlyCli::AptlyLoad.new.configure_with($config_file) + handle_global_options options + aptly_command = AptlyCli::AptlyRepo.new(config, options) puts aptly_command.repo_list() end end @@ -132,7 +184,9 @@ command :repo_package_query do |c| c.option '--with_deps', 'Return results with dependencies' c.option '--format FORMAT', String, 'Format type to return, compact by default. "details" is an option' c.action do |args, options| - aptly_command = AptlyCli::AptlyRepo.new + config = AptlyCli::AptlyLoad.new.configure_with($config_file) + handle_global_options options + aptly_command = AptlyCli::AptlyRepo.new(config, options) if options.query repo_options = { :name => options.name.to_s, :query => options.query.to_s } elsif options.with_deps and options.query.nil? @@ -163,7 +217,9 @@ command :repo_upload do |c| c.option '--noremove', 'Flag to not remove any files that were uploaded via File API after repo upload' c.option '--forcereplace', 'flag to replace file(s) already in the repo' c.action do |args, options| - aptly_command = AptlyCli::AptlyRepo.new + config = AptlyCli::AptlyLoad.new.configure_with($config_file) + handle_global_options options + aptly_command = AptlyCli::AptlyRepo.new(config, options) puts aptly_command.repo_upload({ :name => options.name, :dir => options.dir, :file => options.file, :noremove => options.noremove, :forcereplace => options.forcereplace }) @@ -177,7 +233,9 @@ command :repo_show do |c| c.example 'description', 'aptly-cli repo_show --name megatronsoftware' c.option '--name NAME', String, 'Local repository name, required' c.action do |args, options| - aptly_command = AptlyCli::AptlyRepo.new + config = AptlyCli::AptlyLoad.new.configure_with($config_file) + handle_global_options options + aptly_command = AptlyCli::AptlyRepo.new(config, options) puts aptly_command.repo_show(options.name) end end @@ -191,7 +249,9 @@ command :publish_drop do |c| c.option '--distribution DISTRIBUTION', String, 'distribution' c.option '--force', 'force published repository removal even if component cleanup fails' c.action do |args, options| - aptly_command = AptlyCli::AptlyPublish.new + config = AptlyCli::AptlyLoad.new.configure_with($config_file) + handle_global_options options + aptly_command = AptlyCli::AptlyPublish.new(config, options) puts aptly_command.publish_drop({ :prefix => options.prefix, :distribution => options.distribution, :force => options.force }) end end @@ -202,7 +262,9 @@ command :publish_list do |c| c.description = 'List published repositories.' c.example 'List published repositories', 'aptly-cli publish_list' c.action do |args, options| - aptly_command = AptlyCli::AptlyPublish.new + config = AptlyCli::AptlyLoad.new.configure_with($config_file) + handle_global_options options + aptly_command = AptlyCli::AptlyPublish.new(config, options) puts aptly_command.publish_list() end end @@ -232,7 +294,9 @@ command :publish_repo do |c| c.option '--gpg_passphrase GPGPASS', String, 'gpg key passphrase (if using over http, would be transmitted in clear text!)' c.option '--gpg_passphrase_file GPGPASSFILE', String, 'gpg passphrase file (local to aptly server/user)' c.action do |args, options| - aptly_command = AptlyCli::AptlyPublish.new + config = AptlyCli::AptlyLoad.new.configure_with($config_file) + handle_global_options options + aptly_command = AptlyCli::AptlyPublish.new(config, options) puts aptly_command.publish_repo(options.name, { :sourcekind => options.sourcekind, :prefix => options.prefix, :label => options.label, :distribution => options.distribution, :origin => options.origin, :forceoverwrite => options.forceoverwrite, @@ -259,7 +323,9 @@ command :publish_update do |c| c.option '--gpg_passphrase GPGPASS', String, 'gpg key passphrase (if using over http, would be transmitted in clear text!)' c.option '--gpg_passphrase_file GPGPASSFILE', String, 'gpg passphrase file (local to aptly server/user)' c.action do |args, options| - aptly_command = AptlyCli::AptlyPublish.new + config = AptlyCli::AptlyLoad.new.configure_with($config_file) + handle_global_options options + aptly_command = AptlyCli::AptlyPublish.new(config, options) puts aptly_command.publish_update({ :prefix => options.prefix, :distribution => options.distribution, :forceoverwrite => options.forceoverwrite, :skip => options.gpg_skip, :batch => options.gpg_batch, :gpgKey => options.gpg_key, :keyring => options.gpg_keyring, :secretKeyring => options.gpg_secret_keyring, @@ -277,7 +343,9 @@ command :snapshot_create do |c| c.option '--repo REPO', String, 'Name of repo to snapshot' c.option '--description DESCRIPTION', String, 'Set description for snapshot' c.action do |args, options| - aptly_command = AptlyCli::AptlySnapshot.new + config = AptlyCli::AptlyLoad.new.configure_with($config_file) + handle_global_options options + aptly_command = AptlyCli::AptlySnapshot.new(config, options) puts aptly_command.snapshot_create(options.name, options.repo, options.description) end end @@ -291,7 +359,9 @@ command :snapshot_delete do |c| c.option '--name NAME', String, 'Local snapshot name, required' c.option '--force', 'Force' c.action do |args, options| - aptly_command = AptlyCli::AptlySnapshot.new + config = AptlyCli::AptlyLoad.new.configure_with($config_file) + handle_global_options options + aptly_command = AptlyCli::AptlySnapshot.new(config, options) puts aptly_command.snapshot_delete(options.name, options.force) end end @@ -304,7 +374,9 @@ command :snapshot_diff do |c| c.option '--name NAME', String, 'Local snapshot name (left)' c.option '--withsnapshot WITHSNAPSHOT', String, 'Snapshot to diff against (right)' c.action do |args, options| - aptly_command = AptlyCli::AptlySnapshot.new + config = AptlyCli::AptlyLoad.new.configure_with($config_file) + handle_global_options options + aptly_command = AptlyCli::AptlySnapshot.new(config, options) puts aptly_command.snapshot_diff(options.name, options.withsnapshot) end end @@ -317,7 +389,9 @@ command :snapshot_list do |c| c.example 'Return list sorted by time', 'aptly-cli snapshot_list --sort time' c.option '--sort', String, 'Set sort by' c.action do |args, options| - aptly_command = AptlyCli::AptlySnapshot.new + config = AptlyCli::AptlyLoad.new.configure_with($config_file) + handle_global_options options + aptly_command = AptlyCli::AptlySnapshot.new(config, options) puts aptly_command.snapshot_list(options.sort) end end @@ -334,7 +408,9 @@ command :snapshot_search do |c| c.option '--withdeps', 'Include package dependencies' c.option '--format FORMAT', String, 'Format the respone of the snapshot search results, compact by default.' c.action do |args, options| - aptly_command = AptlyCli::AptlySnapshot.new + config = AptlyCli::AptlyLoad.new.configure_with($config_file) + handle_global_options options + aptly_command = AptlyCli::AptlySnapshot.new(config, options) puts aptly_command.snapshot_search(options.name, { :query => options.query, :format => options.format, :withdeps => options.withdeps }) end end @@ -346,7 +422,9 @@ command :snapshot_show do |c| c.example 'Show snapshot information for repo named megatronsoftware', 'aptly-cli snapshot_show --name megatronsoftware' c.option '--name NAME', String, 'Local snapshot name, required' c.action do |args, options| - aptly_command = AptlyCli::AptlySnapshot.new + config = AptlyCli::AptlyLoad.new.configure_with($config_file) + handle_global_options options + aptly_command = AptlyCli::AptlySnapshot.new(config, options) puts aptly_command.snapshot_show(options.name) end end @@ -360,7 +438,9 @@ command :snapshot_update do |c| c.option '--new_name NEWNAME', String, 'New name for the snapshot' c.option '--description DESCRIPTION', String, 'Update description for snapshot' c.action do |args, options| - aptly_command = AptlyCli::AptlySnapshot.new + config = AptlyCli::AptlyLoad.new.configure_with($config_file) + handle_global_options options + aptly_command = AptlyCli::AptlySnapshot.new(config, options) puts aptly_command.snapshot_update(options.name, options.new_name, options.description) end end @@ -372,7 +452,9 @@ command :graph do |c| c.example 'description', 'aptly-cli graph png > ~/repo_graph.png' c.option '--type GRAPH_TYPE', String, 'Type of graph to download, present options are png or svg' c.action do |args, options| - aptly_command = AptlyCli::AptlyMisc.new + config = AptlyCli::AptlyLoad.new.configure_with($config_file) + handle_global_options options + aptly_command = AptlyCli::AptlyMisc.new(config, options) puts aptly_command.get_graph(options.type) end end @@ -382,7 +464,9 @@ command :version do |c| c.description = 'Display aptly server version' c.example 'description', 'aptly-cli version' c.action do |args, options| - aptly_command = AptlyCli::AptlyMisc.new + config = AptlyCli::AptlyLoad.new.configure_with($config_file) + handle_global_options options + aptly_command = AptlyCli::AptlyMisc.new(config, options) puts aptly_command.get_version() end end diff --git a/lib/aptly_command.rb b/lib/aptly_command.rb new file mode 100644 index 0000000..5a3030b --- /dev/null +++ b/lib/aptly_command.rb @@ -0,0 +1,55 @@ +class AptlyCommand + def initialize(config, options = nil) + @config = config + options ||= Options.new + + if options.server + @config[:server] = options.server + end + + if options.username + @config[:username] = options.username + end + + if options.password + @config[:password] = options.password + end + + if options.debug + @config[:debug] = options.debug + end + + @config.each do |k, v| + if v == '${PROMPT}' + @config[k.to_sym] = ask("Enter a value for #{k}:") + elsif v == '${PROMPT_PASSWORD}' + @config[k.to_sym] = password("Enter a value for #{k}:") + elsif v == '${KEYRING}' + require 'keyring' + + keyring = Keyring.new + value = keyring.get_password(@config[:server], @config[:username]) + + unless value + # Prompt for password... + value = password("Enter a value for #{k}:") + + # ... and store in keyring + keyring.set_password(@config[:server], @config[:username], value) + end + + @config[k.to_sym] = value + end + end + + base_uri = "#{@config[:proto]}://#{@config[:server]}:#{@config[:port]}/api" + self.class.base_uri base_uri + + if @config[:username] + if @config[:password] + self.class.basic_auth @config[:username].to_s, @config[:password].to_s + end + end + debug_output $stdout if @config[:debug] == true + end +end diff --git a/lib/aptly_file.rb b/lib/aptly_file.rb index 00cfd58..a556aa6 100644 --- a/lib/aptly_file.rb +++ b/lib/aptly_file.rb @@ -1,28 +1,14 @@ require 'aptly_cli/version' +require 'aptly_command' require 'aptly_load' require 'httmultiparty' module AptlyCli # Uploading file into Aptly - class AptlyFile + class AptlyFile < AptlyCommand include HTTMultiParty attr_accessor :file_uri, :package, :local_file_path - # Load aptly-cli.conf and establish base_uri - @config = AptlyCli::AptlyLoad.new.configure_with('/etc/aptly-cli.conf') - base_uri "#{@config[:proto]}://#{@config[:server]}:#{@config[:port]}/api" - - if @config[:username] - if @config[:password] - basic_auth @config[:username].to_s, @config[:password].to_s - end - end - - debug_output $stdout if @config[:debug] == true - - def initialize(file_uri=nil, package=nil, local_file_path=nil) - end - def file_dir uri = '/files' self.class.get uri diff --git a/lib/aptly_load.rb b/lib/aptly_load.rb index 3afce95..c36c6b7 100644 --- a/lib/aptly_load.rb +++ b/lib/aptly_load.rb @@ -20,7 +20,7 @@ def initialize port: 8082 } - @valid_config_keys = @config.keys + @valid_config_keys = @config.keys + [:username, :password, :debug] end # Configure through hash @@ -28,6 +28,8 @@ def configure(opts = {}) opts.each do |k, v| config[k.to_sym] = v if @valid_config_keys.include? k.to_sym end + + @config end # Configure through yaml file @@ -36,7 +38,8 @@ def configure_with(path_to_yaml_file) config = YAML.load(IO.read(path_to_yaml_file)) rescue Errno::ENOENT @log.warn( - 'YAML configuration file couldn\'t be found at /etc/aptly-cli.conf. Using defaults.') + "YAML configuration file couldn\'t be found at " \ + "#{path_to_yaml_file}. Using defaults.") return @config rescue Psych::SyntaxError @log.warn( diff --git a/lib/aptly_misc.rb b/lib/aptly_misc.rb index 5b05d38..fc230d7 100644 --- a/lib/aptly_misc.rb +++ b/lib/aptly_misc.rb @@ -1,25 +1,14 @@ require 'aptly_cli/version' +require 'aptly_command' require 'aptly_load' require 'httmultiparty' require 'json' module AptlyCli # Misc Aptly Class - class AptlyMisc + class AptlyMisc < AptlyCommand include HTTMultiParty - # Load aptly-cli.conf and establish base_uri - @config = AptlyCli::AptlyLoad.new.configure_with('/etc/aptly-cli.conf') - base_uri "#{@config[:proto]}://#{@config[:server]}:#{@config[:port]}/api" - - if @config[:username] - if @config[:password] - basic_auth @config[:username].to_s, @config[:password].to_s - end - end - - debug_output $stdout if @config[:debug] == true - def get_graph(extension) uri = "/graph.#{extension}" self.class.get(uri) diff --git a/lib/aptly_package.rb b/lib/aptly_package.rb index 40d900c..7d64325 100644 --- a/lib/aptly_package.rb +++ b/lib/aptly_package.rb @@ -1,25 +1,14 @@ require 'aptly_cli/version' +require 'aptly_command' require 'aptly_load' require 'httmultiparty' require 'json' module AptlyCli # Aptly Package API - class AptlyPackage + class AptlyPackage < AptlyCommand include HTTMultiParty - # Load aptly-cli.conf and establish base_uri - @config = AptlyCli::AptlyLoad.new.configure_with('/etc/aptly-cli.conf') - base_uri "#{@config[:proto]}://#{@config[:server]}:#{@config[:port]}/api" - - if @config[:username] - if @config[:password] - basic_auth @config[:username].to_s, @config[:password].to_s - end - end - - debug_output $stdout if @config[:debug] == true - def package_show(package_key) uri = "/packages/#{package_key}" self.class.get(uri) diff --git a/lib/aptly_publish.rb b/lib/aptly_publish.rb index e213d7a..ea005e8 100644 --- a/lib/aptly_publish.rb +++ b/lib/aptly_publish.rb @@ -1,25 +1,14 @@ require 'aptly_cli/version' +require 'aptly_command' require 'aptly_load' require 'httmultiparty' require 'json' module AptlyCli # :nodoc: - class AptlyPublish + class AptlyPublish < AptlyCommand include HTTMultiParty - # Load aptly-cli.conf and establish base_uri - @config = AptlyCli::AptlyLoad.new.configure_with('/etc/aptly-cli.conf') - base_uri "#{@config[:proto]}://#{@config[:server]}:#{@config[:port]}/api" - - if @config[:username] - if @config[:password] - basic_auth @config[:username].to_s, @config[:password].to_s - end - end - - debug_output $stdout if @config[:debug] == true - @@available_gpg_options = [:skip, :batch, :gpgKey, :keyring, :secretKeyring, :passphrase, :passphraseFile] @@available_options_for_repo = [:distribution, :label, :origin, diff --git a/lib/aptly_repo.rb b/lib/aptly_repo.rb index 5902ff7..3be0656 100644 --- a/lib/aptly_repo.rb +++ b/lib/aptly_repo.rb @@ -1,22 +1,13 @@ require 'aptly_cli/version' +require 'aptly_command' require 'aptly_load' require 'httmultiparty' require 'json' module AptlyCli # Aptly class to work with Repo API - class AptlyRepo + class AptlyRepo < AptlyCommand include HTTMultiParty - # Load aptly-cli.conf and establish base_uri - @config = AptlyCli::AptlyLoad.new.configure_with('/etc/aptly-cli.conf') - base_uri "#{@config[:proto]}://#{@config[:server]}:#{@config[:port]}/api" - - if @config[:username] - if @config[:password] - basic_auth @config[:username].to_s, @config[:password].to_s - end - end - debug_output $stdout if @config[:debug] == true def repo_create(repo_options = { name: nil, comment: nil, diff --git a/lib/aptly_snapshot.rb b/lib/aptly_snapshot.rb index b301420..445ac9a 100644 --- a/lib/aptly_snapshot.rb +++ b/lib/aptly_snapshot.rb @@ -1,25 +1,14 @@ require 'aptly_cli/version' +require 'aptly_command' require 'aptly_load' require 'httmultiparty' require 'json' module AptlyCli # Aptly class to work with Snapshot API - class AptlySnapshot + class AptlySnapshot < AptlyCommand include HTTMultiParty - # Load aptly-cli.conf and establish base_uri - @config = AptlyCli::AptlyLoad.new.configure_with('/etc/aptly-cli.conf') - base_uri "#{@config[:proto]}://#{@config[:server]}:#{@config[:port]}/api" - - if @config[:username] - if @config[:password] - basic_auth @config[:username].to_s, @config[:password].to_s - end - end - - debug_output $stdout if @config[:debug] == true - def snapshot_delete(name, force=nil) uri = "/snapshots/#{name}" uri += '?force=1' if force == true diff --git a/test/fixtures/aptly-cli_prompts.yaml b/test/fixtures/aptly-cli_prompts.yaml new file mode 100644 index 0000000..4a9839c --- /dev/null +++ b/test/fixtures/aptly-cli_prompts.yaml @@ -0,0 +1,5 @@ +--- +:server: 127.0.0.1 +:port: 8084 +:username: zane +:password: ${PROMPT} diff --git a/test/minitest_helper.rb b/test/minitest_helper.rb index 6d32d1a..4140080 100644 --- a/test/minitest_helper.rb +++ b/test/minitest_helper.rb @@ -4,3 +4,7 @@ $LOAD_PATH.unshift File.expand_path('../lib', __FILE__) require 'aptly_cli' require 'minitest/autorun' + +class Options + attr_accessor :server, :username, :password, :debug +end diff --git a/test/test_aptly_cli_configure.rb b/test/test_aptly_cli_configure.rb index 36854cf..2643c53 100644 --- a/test/test_aptly_cli_configure.rb +++ b/test/test_aptly_cli_configure.rb @@ -1,7 +1,15 @@ require_relative 'minitest_helper' require 'aptly_cli' -class TestAptlyCli < Minitest::Test +module AptlyCli + class AptlyLoad + def ask(_prompt) + 'secret' + end + end +end + +class TestAptlyCli < Minitest::Test attr_reader :test_aptly_load def setup @@ -13,12 +21,12 @@ def test_that_it_has_a_version_number end def test_that_config_loads - assert_equal ({ server: '127.0.0.2', port: 8083 }), + assert_equal ({ server: '127.0.0.2', port: 8083, proto: 'http' }), @test_aptly_load.configure({ server: '127.0.0.2', port: 8083 }) end - + def test_that_config_loads_from_yaml - assert_equal ({ server: '127.0.0.1', port: 8084 }), + assert_equal ({ server: '127.0.0.1', port: 8084, proto: 'http' }), @test_aptly_load.configure_with('test/fixtures/aptly-cli.yaml') end @@ -27,14 +35,14 @@ def test_that_config_loads_defaults_if_bad_yaml @test_aptly_load.configure_with('test/fixtures/aptly-cli_invalid.yaml') end assert_includes out, ('WARN -- : YAML configuration file contains invalid '\ - 'syntax. Using defaults') + 'syntax. Using defaults') end - + def test_that_config_loads_defaults_if_no_yaml out, err = capture_subprocess_io do @test_aptly_load.configure_with('test/fixtures/aptly-cli_no_yaml.yaml') end assert_includes out, ('WARN -- : YAML configuration file couldn\'t '\ - 'be found at /etc/aptly-cli.conf. Using defaults.') + 'be found at') end end diff --git a/test/test_aptly_file.rb b/test/test_aptly_file.rb index 232a558..9ca02d6 100644 --- a/test/test_aptly_file.rb +++ b/test/test_aptly_file.rb @@ -4,14 +4,12 @@ require 'aptly_cli' def post_test_file(location) - file_api_setup = AptlyCli::AptlyFile.new - AptlyCli::AptlyFile.new( - location.to_s, - 'test_1.0_amd64.deb', - 'test/fixtures/test_1.0_amd64.deb') - file_api_setup.file_post(file_uri: location.to_s, - package: 'test/fixtures/test_1.0_amd64.deb', - local_file: 'test/fixtures/test_1.0_amd64.deb') + config = AptlyCli::AptlyLoad.new.configure_with('/no/config') + file_api_setup = AptlyCli::AptlyFile.new(config) + file_api_setup.file_post( + file_uri: location.to_s, + package: 'test/fixtures/test_1.0_amd64.deb', + local_file: 'test/fixtures/test_1.0_amd64.deb') end describe AptlyCli::AptlyFile do @@ -29,7 +27,8 @@ def post_test_file(location) end describe 'API GET files' do - let(:file_api) { AptlyCli::AptlyFile.new } + config = AptlyCli::AptlyLoad.new.configure_with('/no/config') + let(:file_api) { AptlyCli::AptlyFile.new(config) } post_test_file('/testdirfile') def test_file_get @@ -38,7 +37,8 @@ def test_file_get end describe 'API DELETE files' do - let(:file_api) { AptlyCli::AptlyFile.new } + config = AptlyCli::AptlyLoad.new.configure_with('/no/config') + let(:file_api) { AptlyCli::AptlyFile.new(config) } post_test_file('/testdirfiledelete') def test_file_delete @@ -49,9 +49,8 @@ def test_file_delete describe "API POST package files" do - let(:api_file) { AptlyCli::AptlyFile.new('/test', - 'test_1.0_amd64.deb', - 'test/fixtures/test_1.0_amd64.deb') } + config = AptlyCli::AptlyLoad.new.configure_with('/no/config') + let(:api_file) { AptlyCli::AptlyFile.new(config) } let(:data_for_not_found) { api_file.file_get('test_package_not_here') } it 'must have a file_post method' do diff --git a/test/test_aptly_misc.rb b/test/test_aptly_misc.rb index 0589c01..e05e82d 100644 --- a/test/test_aptly_misc.rb +++ b/test/test_aptly_misc.rb @@ -23,7 +23,8 @@ def test_config_password_check end describe 'API Get graph' do - let(:misc_api) { AptlyCli::AptlyMisc.new } + config = AptlyCli::AptlyLoad.new.configure_with('/no/config') + let(:misc_api) { AptlyCli::AptlyMisc.new(config) } def test_graph_request_for_SVG_returns_200 assert_equal '200', misc_api.get_graph(extension = 'svg').code.to_s @@ -35,7 +36,8 @@ def test_graph_request_for_PNG_returns_200 end describe 'API Get Version' do - let(:misc_api) { AptlyCli::AptlyMisc.new } + config = AptlyCli::AptlyLoad.new.configure_with('/no/config') + let(:misc_api) { AptlyCli::AptlyMisc.new(config) } def test_version_returns_valid assert_equal '{"Version"=>"0.9.7"}', misc_api.get_version.to_s diff --git a/test/test_aptly_publish.rb b/test/test_aptly_publish.rb index d4de6ae..3449dc7 100644 --- a/test/test_aptly_publish.rb +++ b/test/test_aptly_publish.rb @@ -9,8 +9,9 @@ end describe 'API List Publish' do - let(:publish_api) { AptlyCli::AptlyPublish.new } - let(:snapshot_api) { AptlyCli::AptlySnapshot.new } + config = AptlyCli::AptlyLoad.new.configure_with('/no/config') + let(:publish_api) { AptlyCli::AptlyPublish.new(config) } + let(:snapshot_api) { AptlyCli::AptlySnapshot.new(config) } def test_publish_list publish_api.publish_drop(distribution: 'publishlisttest1', force: 1) @@ -39,8 +40,9 @@ def test_publish_list end describe 'API Drop Publish' do - let(:publish_api) { AptlyCli::AptlyPublish.new } - let(:snapshot_api) { AptlyCli::AptlySnapshot.new } + config = AptlyCli::AptlyLoad.new.configure_with('/no/config') + let(:publish_api) { AptlyCli::AptlyPublish.new(config) } + let(:snapshot_api) { AptlyCli::AptlySnapshot.new(config) } def test_publish_drop publish_api.publish_drop(distribution: 'precisetestdrop', force: 1) @@ -58,8 +60,9 @@ def test_publish_drop end describe 'API Publish Repo' do - let(:publish_api) { AptlyCli::AptlyPublish.new } - let(:snapshot_api) { AptlyCli::AptlySnapshot.new } + config = AptlyCli::AptlyLoad.new.configure_with('/no/config') + let(:publish_api) { AptlyCli::AptlyPublish.new(config) } + let(:snapshot_api) { AptlyCli::AptlySnapshot.new(config) } def test_publish_snapshot snapshot_api.snapshot_delete('testrepo_snap_to_publish', 1) @@ -77,8 +80,9 @@ def test_publish_snapshot end describe 'API Update Publish Point' do - let(:publish_api) { AptlyCli::AptlyPublish.new } - let(:snapshot_api) { AptlyCli::AptlySnapshot.new } + config = AptlyCli::AptlyLoad.new.configure_with('/no/config') + let(:publish_api) { AptlyCli::AptlyPublish.new(config) } + let(:snapshot_api) { AptlyCli::AptlySnapshot.new(config) } def test_publish_single_repo publish_api.publish_drop(distribution: 'precisetest3', force: 1) diff --git a/test/test_aptly_repo.rb b/test/test_aptly_repo.rb index f045075..e449396 100644 --- a/test/test_aptly_repo.rb +++ b/test/test_aptly_repo.rb @@ -8,11 +8,9 @@ end describe 'API Upload to Repo' do - let(:repo_api) { AptlyCli::AptlyRepo.new } - let(:file_api) { AptlyCli::AptlyFile.new( - '/testdir', - 'test_1.0_amd64.deb', - 'test/fixtures/test_1.0_amd64.deb')} + config = AptlyCli::AptlyLoad.new.configure_with('/no/config') + let(:repo_api) { AptlyCli::AptlyRepo.new(config) } + let(:file_api) { AptlyCli::AptlyFile.new(config) } def test_repo_upload file_api.file_post(file_uri: '/testdir', @@ -28,7 +26,8 @@ def test_repo_upload end describe 'API Create Repo' do - let(:repo_api) { AptlyCli::AptlyRepo.new } + config = AptlyCli::AptlyLoad.new.configure_with('/no/config') + let(:repo_api) { AptlyCli::AptlyRepo.new(config) } def test_repo_creation repo_api.repo_delete(name: 'testrepocreate', @@ -43,7 +42,8 @@ def test_repo_creation end describe 'API Show Repo' do - let(:repo_api) { AptlyCli::AptlyRepo.new } + config = AptlyCli::AptlyLoad.new.configure_with('/no/config') + let(:repo_api) { AptlyCli::AptlyRepo.new(config) } def test_repo_show repo_api.repo_delete(name: 'testrepotoshow', @@ -59,12 +59,10 @@ def test_repo_show end describe 'API Package Query Repo' do - let(:repo_api) { AptlyCli::AptlyRepo.new } - let(:file_api) { AptlyCli::AptlyFile.new( - '/testdir2', - 'test_1.0_amd64.deb', - 'test/fixtures/test_1.0_amd64.deb')} - + config = AptlyCli::AptlyLoad.new.configure_with('/no/config') + let(:repo_api) { AptlyCli::AptlyRepo.new(config) } + let(:file_api) { AptlyCli::AptlyFile.new(config) } + def test_package_query_with_name repo_api.repo_delete(name: 'testrepotoquery', force: true) @@ -86,7 +84,8 @@ def test_package_query_with_name end describe 'API List Repo' do - let(:repo_api) { AptlyCli::AptlyRepo.new } + config = AptlyCli::AptlyLoad.new.configure_with('/no/config') + let(:repo_api) { AptlyCli::AptlyRepo.new(config) } def test_list_repo_http_response assert_equal repo_api.repo_list.code.to_s, '200' @@ -94,7 +93,8 @@ def test_list_repo_http_response end describe 'API Edit Repo' do - let(:repo_api) { AptlyCli::AptlyRepo.new } + config = AptlyCli::AptlyLoad.new.configure_with('/no/config') + let(:repo_api) { AptlyCli::AptlyRepo.new(config) } def test_repo_edit_default_distribution repo_api.repo_delete(name: 'testrepotoedit', @@ -114,7 +114,8 @@ def test_repo_edit_default_distribution end describe 'API Delete Repo' do - let(:repo_api) { AptlyCli::AptlyRepo.new } + config = AptlyCli::AptlyLoad.new.configure_with('/no/config') + let(:repo_api) { AptlyCli::AptlyRepo.new(config) } def test_repo_delete repo_api.repo_create(name: 'testrepodelete', @@ -127,7 +128,8 @@ def test_repo_delete end describe 'API Upload to Repo, failure scenario' do - let(:repo_api_fail) { AptlyCli::AptlyRepo.new } + config = AptlyCli::AptlyLoad.new.configure_with('/no/config') + let(:repo_api_fail) { AptlyCli::AptlyRepo.new(config) } let(:data) { repo_api_fail.repo_upload({ name: 'testrepo', dir: 'rockpackages', file: 'test_package_not_here', diff --git a/test/test_aptly_snapshot.rb b/test/test_aptly_snapshot.rb index 20890e2..07407c6 100644 --- a/test/test_aptly_snapshot.rb +++ b/test/test_aptly_snapshot.rb @@ -9,8 +9,9 @@ end describe 'API Delete Snapshot' do - let(:snapshot_api) { AptlyCli::AptlySnapshot.new } - let(:publish_api) { AptlyCli::AptlyPublish.new } + config = AptlyCli::AptlyLoad.new.configure_with('/no/config') + let(:snapshot_api) { AptlyCli::AptlySnapshot.new(config) } + let(:publish_api) { AptlyCli::AptlyPublish.new(config) } def test_snapshot_force_delete snapshot_api.snapshot_create( @@ -50,7 +51,8 @@ def test_that_snapshot_delete_returns_200 end describe 'API Create and List Snapshot' do - let(:snapshot_api) { AptlyCli::AptlySnapshot.new } + config = AptlyCli::AptlyLoad.new.configure_with('/no/config') + let(:snapshot_api) { AptlyCli::AptlySnapshot.new(config) } def test_snapshot_create snapshot_api.snapshot_delete( @@ -76,7 +78,8 @@ def test_that_snapshot_list_returns_results end describe 'API Update Snapshot' do - let(:snapshot_api) { AptlyCli::AptlySnapshot.new } + config = AptlyCli::AptlyLoad.new.configure_with('/no/config') + let(:snapshot_api) { AptlyCli::AptlySnapshot.new(config) } def test_snapshot_update_name snapshot_api.snapshot_delete('testrepo_snap_update_test', 1) @@ -109,7 +112,8 @@ def test_failed_snapshot_show_snapshot_returns_404 end describe 'API Search Snapshot' do - let(:snapshot_api) { AptlyCli::AptlySnapshot.new } + config = AptlyCli::AptlyLoad.new.configure_with('/no/config') + let(:snapshot_api) { AptlyCli::AptlySnapshot.new(config) } def test_snapshot_search_for_all_with_details snapshot_api.snapshot_delete('testrepo_snap_for_search_test', 1) @@ -135,10 +139,12 @@ def test_snapshot_search_for_specific_package end describe 'API Diff Snapshot' do - let(:snapshot_api) { AptlyCli::AptlySnapshot.new } + config = AptlyCli::AptlyLoad.new.configure_with('/no/config') + let(:snapshot_api) { AptlyCli::AptlySnapshot.new(config) } end describe 'API Show Snapshot' do - let(:snapshot_api) { AptlyCli::AptlySnapshot.new } + config = AptlyCli::AptlyLoad.new.configure_with('/no/config') + let(:snapshot_api) { AptlyCli::AptlySnapshot.new(config) } end end