From 4a9d174b913f0688a46d7efebc3c227799480cc1 Mon Sep 17 00:00:00 2001 From: Robert Speicher Date: Tue, 16 Feb 2016 21:29:54 -0500 Subject: Alphabetize Development doc index [ci skip] --- doc/development/README.md | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) (limited to 'doc/development') diff --git a/doc/development/README.md b/doc/development/README.md index d5bf166ad32..f1050c635b7 100644 --- a/doc/development/README.md +++ b/doc/development/README.md @@ -1,11 +1,11 @@ # Development - [Architecture](architecture.md) of GitLab -- [Shell commands](shell_commands.md) in the GitLab codebase -- [Rake tasks](rake_tasks.md) for development +- [Benchmarking](benchmarking.md) - [CI setup](ci_setup.md) for testing GitLab +- [How to dump production data to staging](dump_db.md) +- [Migration Style Guide](migration_style_guide.md) for creating safe migrations +- [Rake tasks](rake_tasks.md) for development +- [Shell commands](shell_commands.md) in the GitLab codebase - [Sidekiq debugging](sidekiq_debugging.md) - [UI guide](ui_guide.md) for building GitLab with existing css styles and elements -- [Migration Style Guide](migration_style_guide.md) for creating safe migrations -- [How to dump production data to staging](dump_db.md) -- [Benchmarking](benchmarking.md) -- cgit v1.2.1 From e82b17fa43822d765cad1b813227032b267b3781 Mon Sep 17 00:00:00 2001 From: Robert Speicher Date: Tue, 16 Feb 2016 21:31:14 -0500 Subject: Fix the "How to dump production data" link [ci skip] --- doc/development/README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) (limited to 'doc/development') diff --git a/doc/development/README.md b/doc/development/README.md index f1050c635b7..4226dc3df12 100644 --- a/doc/development/README.md +++ b/doc/development/README.md @@ -3,7 +3,7 @@ - [Architecture](architecture.md) of GitLab - [Benchmarking](benchmarking.md) - [CI setup](ci_setup.md) for testing GitLab -- [How to dump production data to staging](dump_db.md) +- [How to dump production data to staging](db_dump.md) - [Migration Style Guide](migration_style_guide.md) for creating safe migrations - [Rake tasks](rake_tasks.md) for development - [Shell commands](shell_commands.md) in the GitLab codebase -- cgit v1.2.1 From 6053ad847400443e8ab870cc6a4bcb14be236fb3 Mon Sep 17 00:00:00 2001 From: Robert Speicher Date: Tue, 16 Feb 2016 22:09:00 -0500 Subject: Add "Gotchas" development doc --- doc/development/README.md | 1 + doc/development/gotchas.md | 104 +++++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 105 insertions(+) create mode 100644 doc/development/gotchas.md (limited to 'doc/development') diff --git a/doc/development/README.md b/doc/development/README.md index 4226dc3df12..b9a0d81e5ba 100644 --- a/doc/development/README.md +++ b/doc/development/README.md @@ -3,6 +3,7 @@ - [Architecture](architecture.md) of GitLab - [Benchmarking](benchmarking.md) - [CI setup](ci_setup.md) for testing GitLab +- [Gotchas](gotchas.md) to avoid - [How to dump production data to staging](db_dump.md) - [Migration Style Guide](migration_style_guide.md) for creating safe migrations - [Rake tasks](rake_tasks.md) for development diff --git a/doc/development/gotchas.md b/doc/development/gotchas.md new file mode 100644 index 00000000000..d2d8a6119dd --- /dev/null +++ b/doc/development/gotchas.md @@ -0,0 +1,104 @@ +# Gotchas + +The purpose of this guide is to document potential "gotchas" that contributors +might encounter or should avoid during development of GitLab CE and EE. + +## Don't `describe` symbols + +Consider the following model spec: + +```ruby +require 'rails_helper' + +describe User do + describe :to_param do + it 'converts the username to a param' do + user = described_class.new(username: 'John Smith') + + expect(user.to_param).to eq 'john-smith' + end + end +end +``` + +When run, this spec doesn't do what we might expect: + +```sh +spec/models/user_spec.rb|6 error| Failure/Error: u = described_class.new NoMethodError: undefined method `new' for :to_param:Symbol +``` + +### Solution + +Except for the top-level `describe` block, always provide a String argument to +`describe`. + +## Don't `rescue Exception` + +See ["Why is it bad style to `rescue Exception => e` in Ruby?"][Exception]. + +_**Note:** This rule is [enforced automatically by +Rubocop](https://gitlab.com/gitlab-org/gitlab-ce/blob/8-4-stable/.rubocop.yml#L911-914)._ + +[Exception]: http://stackoverflow.com/q/10048173/223897 + +## Don't use inline CoffeeScript in views + +Using the inline `:coffee` or `:coffeescript` Haml filters comes with a +performance overhead. + +We've [removed these two filters entirely](https://gitlab.com/gitlab-org/gitlab-ce/blob/8-5-stable/config/initializers/haml.rb) +through an initializer. + +### Further reading + +- Pull Request: [Replace CoffeeScript block into JavaScript in Views](https://git.io/vztMu) +- Stack Overflow: [Performance implications of using :coffescript filter inside HAML templates?](http://stackoverflow.com/a/17571242/223897) + +## ID-based CSS selectors need to be a bit more specific + +Normally, because HTML `id` attributes need to be unique to the page, it's +perfectly fine to write some JavaScript like the following: + +```javascript +$('#js-my-selector').hide(); +``` + +But there's a feature of GitLab's Markdown processing that will automatically +add `id` attributes underneath header elements in order to make them linkable. +The content of the header is ["dasherized"][ToC Processing] and used in the `id` +attribute. + +Unfortunately, this feature makes it possible for user-generated content to +create a header element with the same `id` attribute we're using in our +selector, potentially breaking the JavaScript behavior. A user could break the +above example JavaScript with the following Markdown: + +```markdown +## JS My Selector +``` + +Which gets converted to the following HTML after processing: + +```html +

+ + JS My Selector +

+``` + +[ToC Processing]: https://gitlab.com/gitlab-org/gitlab-ce/blob/8-4-stable/lib/banzai/filter/table_of_contents_filter.rb#L31-37 + +### Solution + +The current recommended fix for this is to make our selectors slightly more +specific: + +```javascript +$('div#js-my-selector').hide(); +``` + +### Further reading + +- Issue: [Merge request ToC anchor conflicts with tabs](https://gitlab.com/gitlab-org/gitlab-ce/issues/3908) +- Merge Request: [Make tab target selectors less naive](https://gitlab.com/gitlab-org/gitlab-ce/merge_requests/2023) +- Merge Request: [Make cross-project reference's clipboard target less naive](https://gitlab.com/gitlab-org/gitlab-ce/merge_requests/2024) -- cgit v1.2.1 From 0afe2e051332dbcf69804576ad326cfc4627fc79 Mon Sep 17 00:00:00 2001 From: Robert Speicher Date: Wed, 17 Feb 2016 15:35:28 -0500 Subject: Update Gotchas doc [ci skip] --- doc/development/gotchas.md | 15 +++++++-------- 1 file changed, 7 insertions(+), 8 deletions(-) (limited to 'doc/development') diff --git a/doc/development/gotchas.md b/doc/development/gotchas.md index d2d8a6119dd..21078c8d6f9 100644 --- a/doc/development/gotchas.md +++ b/doc/development/gotchas.md @@ -46,8 +46,8 @@ Rubocop](https://gitlab.com/gitlab-org/gitlab-ce/blob/8-4-stable/.rubocop.yml#L9 Using the inline `:coffee` or `:coffeescript` Haml filters comes with a performance overhead. -We've [removed these two filters entirely](https://gitlab.com/gitlab-org/gitlab-ce/blob/8-5-stable/config/initializers/haml.rb) -through an initializer. +_**Note:** We've [removed these two filters](https://gitlab.com/gitlab-org/gitlab-ce/blob/8-5-stable/config/initializers/haml.rb) +in an initializer._ ### Further reading @@ -63,21 +63,20 @@ perfectly fine to write some JavaScript like the following: $('#js-my-selector').hide(); ``` -But there's a feature of GitLab's Markdown processing that will automatically -add `id` attributes underneath header elements in order to make them linkable. -The content of the header is ["dasherized"][ToC Processing] and used in the `id` -attribute. +However, there's a feature of GitLab's Markdown processing that [automatically +adds anchors to header elements][ToC Processing], with the `id` attribute being +automatically generated based on the content of the header. Unfortunately, this feature makes it possible for user-generated content to create a header element with the same `id` attribute we're using in our selector, potentially breaking the JavaScript behavior. A user could break the -above example JavaScript with the following Markdown: +above example with the following Markdown: ```markdown ## JS My Selector ``` -Which gets converted to the following HTML after processing: +Which gets converted to the following HTML: ```html

-- cgit v1.2.1