gitlab-org--gitlab-foss/spec
Dmitriy Zaporozhets 76b7e24f85 Merge branch 'edit-on-fork' into 'master'
Automatically fork a project when not allowed to edit a file.

Fixes #3215.

To do:

- [ ] Add tests

-----

## "Edit" button on file in a project the user does NOT have write access to

![edit_file](/uploads/7602157420768aef483a6586bba2d164/edit_file.png)

## Clicking will automatically create a fork

![during_fork](/uploads/32f4f5dff9f24ea99522000b0bf881c5/during_fork.png)

## When the fork has been created, the user is returned to the edit page on the original project with a notice

![edit_notice](/uploads/94ed1319404370ff1e9c0d672fb41e03/edit_notice.png)

## The user cannot change the target branch and is informed that editing will start an MR

![edit_footer](/uploads/4da68d4795c7177e575b7c434d16eeae/edit_footer.png)

## Hitting "Commit changes" will commit and start an MR from my fork to the origin project

![Screen_Shot_2015-12-17_at_23.38.08](/uploads/d777a4db6f38a5a1be84031694465bc1/Screen_Shot_2015-12-17_at_23.38.08.png)

-----

## "Create file, "Upload file" and "New directory" buttons in a project the user does NOT have write access to

![new_directory](/uploads/72f556248f30d6652523bbb4be01b3e0/new_directory.png)

## Clicking any of these options will automatically create a fork

![during_fork](/uploads/32f4f5dff9f24ea99522000b0bf881c5/during_fork.png)

## When the fork has been created, the user is returned to the tree page on the original project with a notice

![new_directory_notice](/uploads/a1a3e11308ae0e8f0913fae6813a37ed/new_directory_notice.png)

## Clicking "New directory" again will show the modal. The user cannot change the target branch and is informed that editing will start an MR

![new_dir](/uploads/99ca8cbfb2f70603e352b3fdf67b6281/new_dir.png)

## Hitting "Create directory" will commit and start an MR from my fork to the origin project

![Screen_Shot_2015-12-17_at_23.39.19](/uploads/3713d0235abf831361b803a6198c5bc1/Screen_Shot_2015-12-17_at_23.39.19.png)

cc @dzaporozhets @skyruler

See merge request !2145
2015-12-24 12:24:57 +00:00
..
benchmarks Move Markdown/reference logic from Gitlab::Markdown to Banzai 2015-12-15 15:51:16 +01:00
controllers Fix specs 2015-12-18 17:09:58 +01:00
factories Migrate CI::Project to Project 2015-12-11 18:02:09 +01:00
features Merge branch 'fix/ci-runners-token-persistence' into 'master' 2015-12-23 12:07:37 +00:00
finders Port GitLab EE ProjectsFinder changes 2015-11-20 15:53:04 +01:00
fixtures Use URL helpers in specs 2015-12-03 14:00:09 +01:00
helpers fix specs 2015-12-22 23:12:23 +02:00
javascripts Add helper methods to JS validation spec for invalid branch names 2015-12-22 15:32:57 -02:00
lib Backport JIRA service 2015-12-18 14:19:48 -06:00
mailers Migrate CI::Services and CI::WebHooks to Services and WebHooks 2015-12-10 16:04:08 +01:00
models Merge branch 'fix/visibility-level-setting-in-forked-projects' into 'master' 2015-12-24 12:09:38 +00:00
requests Merge branch 'branch-invalid-name' into 'master' 2015-12-24 11:42:25 +00:00
routing Move partial to right place and fix tests. 2015-09-08 15:14:14 +01:00
services Merge branch 'fix/visibility-level-setting-in-forked-projects' into 'master' 2015-12-24 12:09:38 +00:00
support Backport JIRA service 2015-12-18 14:19:48 -06:00
tasks/gitlab Add lfs to backup specs. 2015-11-19 10:43:45 +01:00
views/help Allow non-admin users to see version information 2015-09-23 17:18:15 -04:00
workers Fixed Rubocop offenses 2015-12-15 00:53:52 -02:00
factories.rb Fixed Rubocop offenses 2015-12-15 00:53:52 -02:00
factories_spec.rb
rails_helper.rb Started on the actual rspec 3 upgrade 2015-06-22 12:12:49 +02:00
spec_helper.rb fix notification_service specs 2015-11-30 11:21:10 +02:00
teaspoon_env.rb