Skip to content

stimpack establishes and implements a set of conventions for splitting up large monoliths

License

Notifications You must be signed in to change notification settings

Flowspace-Team/stimpack

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

32 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Stimpack

stimpack establishes and implements a set of conventions for splitting up large monoliths built on top of packwerk. With stimpack, new packages' autoload paths are automatically added to Rails, so your code will immediately become usable and loadable without additional configuration.

Here is an example application that uses stimpack:

package.yml # root level pack
app/ # Unpackaged code
  models/
  ...
packs/
  my_domain/
    package.yml # See the packwerk docs for more info
    deprecated_references.yml # See the packwerk docs for more info
    app/
      public/ # Recommended location for public API
        my_domain.rb # creates the primary namespaces
        my_domain/
          my_subdomain.rb
      services/ # Private services
        my_domain/
          some_private_class.rb
      models/ # Private models
        some_other_non_namespaced_private_model.rb # this works too
        my_domain/
          my_private_namespacd_model.rb
      controllers/
      views/
    config/
      initializers/ # Initializers can live in packs and load as expected
    lib/
      tasks/
    spec/ # With stimpack, specs for a pack live next to the pack
      public/
        my_domain_spec.rb
        my_domain/
          my_subdomain_spec.rb
      services/
        my_domain/
          some_private_class_spec.rb
      models/
        some_other_non_namespaced_private_model_spec.rb
        my_domain/
          my_private_namespaced_model_spec.rb
      factories/ # Stimpack will automatically load pack factories into FactoryBot
        my_domain/
          my_private_namespaced_model_factory.rb
  my_other_domain/
    ... # other pack's have a similar structure
  my_other_other_domain/
    ...

Usage

Setting up stimpack is straightforward. Simply by including stimpack in your Gemfile in all environments, stimpack will automatically hook into and configure Rails.

From there, you can create a ./packs folder and structure it using the conventions listed above.

If you wish to use a different directory name, eg components instead of packs, you can customize this in your config/application.rb file:

# Customize Stimpack's root directory. Note that this has to be done _before_ the Application
# class is declared.
Stimpack.config.root = "components"

module MyCoolApp
  class Application < Rails::Application
    # ...
  end
end

Splitting routes

stimpack allows you to split your application routes for every pack. You just have to create a file describing your routes and then draw them in your root config/routes.rb file.

# packs/my_domain/config/routes/my_domain.rb
resources :my_resource

# config/routes.rb
draw(:my_domain)

Making your Package an Engine

Add engine: true to your package.yml to make it an actual Rails engine:

# packs/my_pack/package.yml
enforce_dependencies: true
enforce_privacy: true
metadata:
  engine: true

Contributing

Bug reports and pull requests are welcome on GitHub at https://github.com/Gusto/stimpack.

About

stimpack establishes and implements a set of conventions for splitting up large monoliths

Resources

License

Code of conduct

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Ruby 98.3%
  • Shell 1.7%