Simple tool to deploy OBS via zypper to our reference server
Just run:
gem install obs_deploy
obs_deploy deployed-version [--host <server>]
obs_deploy available-package [<product>] [<package-name>]
obs_deploy refresh-repositories
After checking out the repo, run bin/setup
to install dependencies. Then, run rake spec
to run the tests. You can also run bin/console
for an interactive prompt that will allow you to experiment.
To install this gem onto your local machine, run bundle exec rake install
. To release a new version, update the version number in version.rb
, and then run bundle exec rake release
, which will create a git tag for the version, push git commits and tags, and push the .gem
file to rubygems.org.
To generate the fixtures (located under spec/fixtures
), we are using curl -si $URL > $FIXTURE
On the checked out source, run the following:
ruby -Ilib bin/obs_deploy -v
if you want to run it against the OBS appliance running on VirtualBox:
-
Make sure that you can ssh without password into your VM
-
Make sure the appliance is running in bridge mode
-
build the docker image as:
docker build -t $USER/obs_deploy .
-
then run the container as:
make docker-dev
Now you are inside the container and should be able to ping the obs appliance.
From there:
$ obs_deploy refresh-repositories --host=$APPLIANCE_IP
If you want to add new command to the cli, please read the dry-cli
documentation https://dry-rb.org/gems/dry-cli/0.4/. The commands are in the obs_deploy/cli/commands
directory.
The commands are being sent via ssh and ssh is being called via cheetah
https://github.com/openSUSE/cheetah. Please Read the ssh.rb
file, specially the SSH#run
method
Bug reports and pull requests are welcome on GitHub at https://github.com/openSUSE/obs_deploy.