Commit dab0b117 authored by Rémy Coutable's avatar Rémy Coutable

Merge branch 'docs-update-ee_features.md' into 'master'

Update EE docs to allow not having EE namespace

See merge request gitlab-org/gitlab-ee!3194
parents 74db6d2f e1168216
...@@ -23,31 +23,49 @@ spec helper `stub_licensed_features` in `EE::LicenseHelpers`. ...@@ -23,31 +23,49 @@ spec helper `stub_licensed_features` in `EE::LicenseHelpers`.
## Separation of EE code ## Separation of EE code
Merging changes from GitLab CE to EE can result in numerous conflicts. We want a [single code base][] eventually, but before we reach the goal,
To reduce conflicts, EE code should be separated in to the `EE` module we still need to merge changes from GitLab CE to EE. To help us get there,
as much as possible. we should make sure that we no longer edit CE files in place in order to
implement EE features.
When referencing constants *outside* of the `EE` namespace from within it, you
should always use absolute constants - e.g., `::User` instead of `User`. This Instead, all EE codes should be put inside the `ee/` top-level directory, and
will prevent `::EE::User` from being picked instead of `::User`. Follow this tests should be put inside `spec/ee/`. We don't use `ee/spec` for now due to
rule even if the constant doesn't exist in the `EE` namespace at present - it technical limitation. The rest of codes should be as close as to the CE files.
may be added in the future.
[single code base]: https://gitlab.com/gitlab-org/gitlab-ee/issues/2952#note_41016454
### Classes vs. Module Mixins
### EE-only features
If the feature being developed is not present in any form in CE,
separation is easy - build the class entirely in the `EE` namespace. If the feature being developed is not present in any form in CE, we don't
need to put the codes under `EE` namespace. For example, an EE model could
go into: `ee/app/models/awesome.rb` using `Awesome` as the class name. This
is applied not only to models. Here's a list of other examples:
- `ee/app/controllers/foos_controller.rb`
- `ee/app/finders/foos_finder.rb`
- `ee/app/helpers/foos_helper.rb`
- `ee/app/mailers/foos_mailer.rb`
- `ee/app/models/foo.rb`
- `ee/app/policies/foo_policy.rb`
- `ee/app/serializers/foo_entity.rb`
- `ee/app/serializers/foo_serializer.rb`
- `ee/app/services/foo/create_service.rb`
- `ee/app/validators/foo_attr_validator.rb`
- `ee/app/workers/foo_worker.rb`
### EE features based on CE features
For features that build on existing CE features, write a module in the For features that build on existing CE features, write a module in the
`EE` namespace and `prepend` it in the CE class. This makes conflicts `EE` namespace and `prepend` it in the CE class. This makes conflicts
less likely to happen during CE to EE merges because only one line is less likely to happen during CE to EE merges because only one line is
added to the CE class - the `prepend` line. added to the CE class - the `prepend` line.
### Adding EE-only files Since the module would require an `EE` namespace, the file should also be
put in an `ee/` sub-directory. For example, we want to extend the user model
in EE, so we have a module called `::EE::User` put inside
`ee/app/models/ee/user.rb`.
Place EE-only controllers, finders, helpers, mailers, models, policies, This is also not just applied to models. Here's a list of other examples:
serializers/entities, services, validators and workers in the top-level
`EE` module namespace, and in the `ee/` specific sub-directory:
- `ee/app/controllers/ee/foos_controller.rb` - `ee/app/controllers/ee/foos_controller.rb`
- `ee/app/finders/ee/foos_finder.rb` - `ee/app/finders/ee/foos_finder.rb`
...@@ -61,8 +79,6 @@ serializers/entities, services, validators and workers in the top-level ...@@ -61,8 +79,6 @@ serializers/entities, services, validators and workers in the top-level
- `ee/app/validators/ee/foo_attr_validator.rb` - `ee/app/validators/ee/foo_attr_validator.rb`
- `ee/app/workers/ee/foo_worker.rb` - `ee/app/workers/ee/foo_worker.rb`
This applies to both EE-only classes and EE module mixins.
#### Overriding CE methods #### Overriding CE methods
To override a method present in the CE codebase, use `prepend`. It To override a method present in the CE codebase, use `prepend`. It
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment