Simple, usable web application for deploying complex applications to the cloud; wrapping cloud native SDK/CLIs.
suse-rancher-setup depends on, primarily:
- Ruby 3.1 (currently 3.1.2)
- Rails 7.1
- Sqlite 3
- AWS-CLI (v1 or v2)
- ec2metadata
- helm ~3.4
- kuberlr (or kubectl 1.24)
This Ruby on Rails-bsed project uses rvm to manage a virtual environment for development.
-
Clone this project
-
RVM will prompt you to install the required ruby version, if necessary, when entering the project directory.
-
Install dependencies
gem install bundler bundle
If you have trouble with nokogiri, make sure you have development versions of libxml2 & libxslt installed. Install also sqlite-devel. On (open)SUSE:
sudo zypper in libxml2-devel libxslt-devel sqlite3-devel
-
Create a local config file
cp config/example_config.yml config/config.yml
Only an example config is included in the project for reference. Your working config is not included in the source repository.
-
Initialize a development database
rails db:setup
-
Start a development server on http://localhost:3000
rails server -b localhost -p 3000
-
If running the Azure engine, the active subscription ID is detected via IMDS (e.g., the suse-rancher-setup instance must run in the subscription where it will deploy). When developing locally, the subscription must be set via the
rails console
instead, before interacting with the Azure API:Azure::Subscription.new(value: "YOUR SUBSCRIPTION UUID").save
Please be sure to include a screenshot with any view or style changes.
To run the full test suite using all avialable recordings, run rails coverage
. Alternatively, specify a workflow and engine set, as would be defined in a production config, in environment variables, and only specs appropriate to that workflow will be run:
LASSO_WORKFLOW
- name of the workflow engineLASSO_ENGINES
- comma-separated list of engines to load
Example:
LASSO_WORKFLOW=RancherOnAks LASSO_ENGINES=Azure,ShirtSize,PreFlight,RancherOnAks,Helm rspec
💡 Use the environment variable RERECORD=true
when re-recording the test suite.
The Azure interface uses the Azure REST API; test fixtures are recorded with VCR. To record new tests, delete the old recordings from spec/vcr/$SPEC_NAME
, and set the following environment variables when running rspec
:
APP_ID
- The UUID of the Azure service principalPASSWORD
- the Azure service principal secretTENANT
- the Azure service principal tenant UUIDSUBSCRIPTION
- the Azure subscription UUID where the application will be executed (SP must have permissions)
Due to random selection, a few static values need to be reset on the suite after re-recording. Please follow the inline instructions to update the before(:example)
block in spec/system/RancherOnAks/happy_path_spec.rb .
The AWS interface uses the AWS CLI (aws
); test fixtures are recorded via a harness trap. Please see rails -T vcr
for rake tasks used to maintain the recordings. Your local AWS CLI must be authenticated to the account where Rancher will be deployed.
Due to random selection, a few static values need to be reset on the suite after re-recording. Please follow the inline instructions to update the before(:example)
block in spec/system/RancherOnEks/happy_path_spec.rb .
Each UI & backend component is developed in an independent Rails Engine in order to provide test/dev isolation of components, while allowing for an instance of the Installer to load only the needed components.
rails plugin new engines/$ENGINE_NAME -d sqlite3 --skip-git --mountable --skip-gemfile-entry
- Remove the
Gemfile
,*.gemspec
,lib/$ENGINE_NAME/version.rb
- Remove
require '$ENGINE_NAME/version'
fromlib/$ENGINE_NAME.rb
- Remove any unnecessary components, if desired (mailers, jobs, assets)
- Edit
config/routes.rb
to include a route for the engine, conditioned on the engine being loaded.
Engines are only loaded if the application is configured to do so. To load an engine it must be included in the list Rails.configuration.engines
, defined in config/application.rb
.
Since each engine may define UI elements in the workflow, the order engines are loaded determines the order of the menu entries in the application. The only exception is the 'Welcome' page, which is always first.
One Engine in the workflow should be designated as the 'deployment engine'. This should define the overall workflow and the steps to be performed for the deployment, including authorization for the entire workflow. See engines/rancher_on_eks/app/helpers/rancher_on_eks/authorization_helper.rb for an example.
Add web content to an engine like any other application; it must be routed, have controllers & views, and may use models.
In order to include it in the workflow, menu_entries must be defined for the engine. Menu entries are defined in engines/$ENGINE/lib/$ENGINE.rb
as follows:
module SomeEngineName
def self.menu_entries
[
{ caption: 'Do a thing', icon: 'manage_accounts', target: '/some_engine_name/do_a_thing' },
{ caption: 'Do something else', icon: 'location_on', target: '/some_engine_name/do_something_else' },
]
end
end
self.menu_entries
should return a list of dictionaries, each defining three attributes:
caption:
the text to use on the main menuicon:
the name of the EOS icon to use on the main menutarget:
the route to the first page of the workflow. This must include the top-level directory where the engine is mounted, as defined inconfig/routes.rb
.
Translations should be provided under the engines.$ENGINE
namespace.
While the web content of a component is defined exclusively by the engine, there are some user interface conventions defined; complying with application UI conventions provides a consistent experience for end users.
Page views should adhere to the following template:
= page_header(t('engines.$ENGINE.$MENU_ENTRY.title'))
-# body
YOUR CONTENT HERE
-# end
= render('layouts/navigation_buttons') do
= previous_step_button()
= next_step_button()
suse-rancher-setup uses and conforms to the EOS Design System.
In order to comply with AWS Marketplace requirements, the AWS module does not prompt for credentials. In order to use AWS via this application, it must be run either on an EC2 instance with an assigned IAM machine role, or credentials must be configured locally in ~/.aws/credentials
.
The minimum IAM permissions required to run the Rancher on EKS workflow are provided as aws-iam/iam_role.json.
suse-rancher-setup includes supporting tools and documents to build on an open build service (OBS) instance, such as https://build.opensuse.org
⚠ Note: before packaging or running in production mode, session storage secrets must be generated and provided as:
- config/credentials.yml.enc
- config/master.key
These files can be generated using bin/rails credentials:edit
and are ignored by git. We recommend storing the key in a secure location.
When updating dependencies, add a categorized entry with a comment, in Gemfile.development.
Please note any new external CLI dependencies in this documentation.
Gems must be included with the ruby framework target; OBS will not accept prebuilt libraries included in gems (like nokogiri and sqlite3 ). I recommend using the following bundler config (.bundle/config
):
---
BUNDLE_BUILD__SQLITE3: "--enable-system-libraries"
BUNDLE_FORCE_RUBY_PLATFORM: "true"
BUNDLE_CACHE_ALL: "false"
Update the changelog for the expected release version, and stage it for git.
💡 Hint: You can use bin/vc
to get the proper format for changelogs, assuming you have osc installed.
bumpversion is used to tag releases; the --allow-dirty
flag will include the changelog in the version bump commit.
bumpversion [major|minor|patch] --allow-dirty
- All steps required for generating a production-ready tarball, including precompiling assets and preparing bootsnap caches, are included in the Makefile task:
make dist
- Copy the specfile and move the tarball to an OBS project dir
cp packaging/* path/of/your/project/
mv *.tar* path/of/your/project/
Copyright © 2022 SUSE LLC. Distributed under the terms of GPL-3.0+ license, see LICENSE for details.