We are always looking for contributions to OSEM. Read this guide on how to do that.
In particular, this community seeks the following types of contributions:
- code: contribute your expertise in an area by helping us expand OSEM
- ideas: participate in an issues thread or start your own to have your voice heard.
- copy editing: fix typos, clarify language, and generally improve the quality of the content of OSEM
We are using Vagrant to create our development environments.
-
Install Vagrant and VirtualBox. Both tools support Linux, MacOS and Windows.
-
Install vagrant-exec:
vagrant plugin install vagrant-exec
-
Clone this code repository:
git clone https://github.com/openSUSE/osem.git
-
Execute Vagrant in the cloned directory:
vagrant up
-
Start your OSEM rails app:
vagrant exec rails server -b 0.0.0.0
-
Check out your OSEM rails app: You can access the app localhost:3000. Whatever you change in your cloned repository will have effect in the development environment. Sign up, the first user will be automatically assigned the admin role.
-
Changed something? Test your changes!:
vagrant exec bundle exec rspec spec
-
Explore the development environment:
vagrant ssh
-
Or issue any standard
rails
/rake
/bundler
command by prependingvagrant exec
vagrant exec bundle exec rake db:migrate
- Prerequisite: familiarity with GitHub Pull Requests and issues.
- Fork the repository and make a pull-request with your changes
- Make sure that the test suite passes before you request a pull and that you comply to our ruby styleguide.
- Please increase code coverage by your pull request (coveralls or simplecov locally will give you insight)
- One of the OSEM maintainers will review your pull-request
- If you are already a contributor and you get a positive review, you can merge your pull-request yourself
- If you are not a contributor already please request a merge via the pull-request comments
We are using rubocop as a style checker. It is checking code style each time the test suite runs. You can run it locally with
vagrant exec bundle exec rubocop
You can read through current enabled rules in .rubocop.yml
file. Explanations of the defined rules can be found in modules Cop::Lint and Cop::Style.
Additionally you can read through the ruby style-guide to better understand core principles.
We are using rspec+capybara+factory girl as a test suite. You can run it locally
vagrant exec bundle exec rspec
OSEM is part of the openSUSE project. We follow all the openSUSE Guiding Principles! If you think someone doesn't do that, please let us know at maintainers@osem.io
GitHub issues are the primary way for communicating about specific proposed changes to this project. If you have other questions feel free to subscribe to the opensuse-web@opensuse.org mailinglist, all OSEM contributors are on that list! Additionally you can use #osem channel on freenode IRC.
Note: We use letter_opener in development environment. You can check out your mails by visiting localhost:3000/letter_opener.
devise_ichain_authenticatable comes with
test mode, which can be useful in development phase in which an iChain proxy is not usually configured or even available. You can enable ichain authentication by setting CONFIG['authentication']['ichain']['enabled']
equal to true
in config.yml
file. You would also need to set following options in devise.rb
:
# Activate the test mode
config.ichain_test_mode = true
# 'testuser' user will be permanently signed in.
config.ichain_force_test_username = "testuser"
# set email of 'testuser'
config.ichain_force_test_attributes = {:email => "testuser@example.com"}