Commit a116779f authored by Alex Kalderimis's avatar Alex Kalderimis

Merge branch 'enable-changelog-api' into 'master'

Remove changelog_api feature flag [RUN ALL RSPEC] [RUN AS-IF-FOSS]

See merge request gitlab-org/gitlab!53890
parents 77dfaba7 95982dcf
---
name: changelog_api
introduced_by_url: '13.9'
rollout_issue_url: https://gitlab.com/gitlab-org/gitlab/-/issues/300043
milestone: '13.9'
type: development
group: group::source code
default_enabled: false
...@@ -281,14 +281,7 @@ Example response: ...@@ -281,14 +281,7 @@ Example response:
## Generate changelog data ## Generate changelog data
> - [Introduced](https://gitlab.com/groups/gitlab-com/gl-infra/-/epics/351) in GitLab 13.9. > [Introduced](https://gitlab.com/groups/gitlab-com/gl-infra/-/epics/351) in GitLab 13.9.
> - It's [deployed behind a feature flag](../user/feature_flags.md), disabled by default.
> - It's disabled on GitLab.com.
> - It's not yet recommended for production use.
> - To use it in GitLab self-managed instances, ask a GitLab administrator to [enable it](#enable-or-disable-generating-changelog-data).
WARNING:
This feature might not be available to you. Check the **version history** note above for details.
Generate changelog data based on commits in a repository. Generate changelog data based on commits in a repository.
...@@ -562,25 +555,6 @@ In an entry, the following variables are available (here `foo.bar` means that ...@@ -562,25 +555,6 @@ In an entry, the following variables are available (here `foo.bar` means that
- `merge_request.reference`: a reference to the merge request that first - `merge_request.reference`: a reference to the merge request that first
introduced the change (for example, `gitlab-org/gitlab!50063`). introduced the change (for example, `gitlab-org/gitlab!50063`).
The `author` and `merge_request` objects might not be present if the data couldn't The `author` and `merge_request` objects might not be present if the data
be determined (for example, when a commit was created without a corresponding merge couldn't be determined. For example, when a commit is created without a
request). corresponding merge request, no merge request is displayed.
### Enable or disable generating changelog data **(CORE ONLY)**
This feature is under development and not ready for production use. It is
deployed behind a feature flag that is **disabled by default**.
[GitLab administrators with access to the GitLab Rails console](../administration/feature_flags.md)
can enable it.
To enable it for a project:
```ruby
Feature.enable(:changelog_api, Project.find(id_of_the_project))
```
To disable it for a project:
```ruby
Feature.disable(:changelog_api, Project.find(id_of_the_project))
```
...@@ -211,8 +211,6 @@ module API ...@@ -211,8 +211,6 @@ module API
desc: 'The commit message to use when committing the changelog' desc: 'The commit message to use when committing the changelog'
end end
post ':id/repository/changelog' do post ':id/repository/changelog' do
not_found! unless Feature.enabled?(:changelog_api, user_project)
branch = params[:branch] || user_project.default_branch_or_master branch = params[:branch] || user_project.default_branch_or_master
access = Gitlab::UserAccess.new(current_user, container: user_project) access = Gitlab::UserAccess.new(current_user, container: user_project)
......
...@@ -612,100 +612,83 @@ RSpec.describe API::Repositories do ...@@ -612,100 +612,83 @@ RSpec.describe API::Repositories do
end end
describe 'POST /projects/:id/repository/changelog' do describe 'POST /projects/:id/repository/changelog' do
context 'when the changelog_api feature flag is enabled' do it 'generates the changelog for a version' do
it 'generates the changelog for a version' do spy = instance_spy(Repositories::ChangelogService)
spy = instance_spy(Repositories::ChangelogService)
allow(Repositories::ChangelogService)
allow(Repositories::ChangelogService) .to receive(:new)
.to receive(:new) .with(
.with( project,
project, user,
user, version: '1.0.0',
version: '1.0.0', from: 'foo',
from: 'foo', to: 'bar',
to: 'bar', date: DateTime.new(2020, 1, 1),
date: DateTime.new(2020, 1, 1), branch: 'kittens',
branch: 'kittens', trailer: 'Foo',
trailer: 'Foo', file: 'FOO.md',
file: 'FOO.md', message: 'Commit message'
message: 'Commit message'
)
.and_return(spy)
allow(spy).to receive(:execute)
post(
api("/projects/#{project.id}/repository/changelog", user),
params: {
version: '1.0.0',
from: 'foo',
to: 'bar',
date: '2020-01-01',
branch: 'kittens',
trailer: 'Foo',
file: 'FOO.md',
message: 'Commit message'
}
) )
.and_return(spy)
expect(response).to have_gitlab_http_status(:ok)
end allow(spy).to receive(:execute)
it 'produces an error when generating the changelog fails' do post(
spy = instance_spy(Repositories::ChangelogService) api("/projects/#{project.id}/repository/changelog", user),
params: {
allow(Repositories::ChangelogService) version: '1.0.0',
.to receive(:new) from: 'foo',
.with( to: 'bar',
project, date: '2020-01-01',
user, branch: 'kittens',
version: '1.0.0', trailer: 'Foo',
from: 'foo', file: 'FOO.md',
to: 'bar', message: 'Commit message'
date: DateTime.new(2020, 1, 1), }
branch: 'kittens', )
trailer: 'Foo',
file: 'FOO.md', expect(response).to have_gitlab_http_status(:ok)
message: 'Commit message' end
)
.and_return(spy) it 'produces an error when generating the changelog fails' do
spy = instance_spy(Repositories::ChangelogService)
allow(spy)
.to receive(:execute) allow(Repositories::ChangelogService)
.and_raise(Gitlab::Changelog::Error.new('oops')) .to receive(:new)
.with(
post( project,
api("/projects/#{project.id}/repository/changelog", user), user,
params: { version: '1.0.0',
version: '1.0.0', from: 'foo',
from: 'foo', to: 'bar',
to: 'bar', date: DateTime.new(2020, 1, 1),
date: '2020-01-01', branch: 'kittens',
branch: 'kittens', trailer: 'Foo',
trailer: 'Foo', file: 'FOO.md',
file: 'FOO.md', message: 'Commit message'
message: 'Commit message'
}
)
expect(response).to have_gitlab_http_status(:internal_server_error)
expect(json_response['message']).to eq('Failed to generate the changelog: oops')
end
end
context 'when the changelog_api feature flag is disabled' do
before do
stub_feature_flags(changelog_api: false)
end
it 'responds with a 404 Not Found' do
post(
api("/projects/#{project.id}/repository/changelog", user),
params: { version: '1.0.0', from: 'foo', to: 'bar' }
) )
.and_return(spy)
expect(response).to have_gitlab_http_status(:not_found)
end allow(spy)
.to receive(:execute)
.and_raise(Gitlab::Changelog::Error.new('oops'))
post(
api("/projects/#{project.id}/repository/changelog", user),
params: {
version: '1.0.0',
from: 'foo',
to: 'bar',
date: '2020-01-01',
branch: 'kittens',
trailer: 'Foo',
file: 'FOO.md',
message: 'Commit message'
}
)
expect(response).to have_gitlab_http_status(:internal_server_error)
expect(json_response['message']).to eq('Failed to generate the changelog: oops')
end end
end end
end end
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