diff --git a/docs/data-sources/project.md b/docs/data-sources/project.md index a4920ae53..df6442f4c 100644 --- a/docs/data-sources/project.md +++ b/docs/data-sources/project.md @@ -43,6 +43,7 @@ data "gitlab_project" "example" { - **namespace_id** (Number) The namespace (group or user) of the project. Defaults to your user. - **path** (String) The path of the repository. - **pipelines_enabled** (Boolean) Enable pipelines for the project. +- **printing_merge_request_link_enabled** (Boolean) Show link to create/view merge request when pushing from the command line - **push_rules** (List of Object) Push rules for the project. (see [below for nested schema](#nestedatt--push_rules)) - **remove_source_branch_after_merge** (Boolean) Enable `Delete source branch` option by default for all new merge requests - **request_access_enabled** (Boolean) Allow users to request member access. diff --git a/docs/resources/project.md b/docs/resources/project.md index 853860526..166336fc8 100644 --- a/docs/resources/project.md +++ b/docs/resources/project.md @@ -73,6 +73,7 @@ resource "gitlab_project" "example-two" { - **pages_access_level** (String) Enable pages access control - **path** (String) The path of the repository. - **pipelines_enabled** (Boolean) Enable pipelines for the project. +- **printing_merge_request_link_enabled** (Boolean) Show link to create/view merge request when pushing from the command line - **push_rules** (Block List, Max: 1) Push rules for the project. (see [below for nested schema](#nestedblock--push_rules)) - **remove_source_branch_after_merge** (Boolean) Enable `Delete source branch` option by default for all new merge requests. - **request_access_enabled** (Boolean) Allow users to request member access. diff --git a/examples/gitlab-managed-state/main.tf b/examples/gitlab-managed-state/main.tf index 48eaf2a1e..56c8140c5 100644 --- a/examples/gitlab-managed-state/main.tf +++ b/examples/gitlab-managed-state/main.tf @@ -41,6 +41,7 @@ resource "gitlab_project" "api" { only_allow_merge_if_all_discussions_are_resolved = true only_allow_merge_if_pipeline_succeeds = true remove_source_branch_after_merge = true + printing_merge_request_link_enabled = true container_registry_enabled = false lfs_enabled = false diff --git a/internal/provider/data_source_gitlab_project.go b/internal/provider/data_source_gitlab_project.go index 6c5a83441..3669f0a75 100644 --- a/internal/provider/data_source_gitlab_project.go +++ b/internal/provider/data_source_gitlab_project.go @@ -134,6 +134,11 @@ var _ = registerDataSource("gitlab_project", func() *schema.Resource { Type: schema.TypeBool, Computed: true, }, + "printing_merge_request_link_enabled": { + Description: "Show link to create/view merge request when pushing from the command line", + Type: schema.TypeBool, + Computed: true, + }, // lintignore: S031 // TODO: Resolve this tfproviderlint issue "push_rules": { Description: "Push rules for the project.", diff --git a/internal/provider/resource_gitlab_project.go b/internal/provider/resource_gitlab_project.go index 095a6a6cb..b2d4164d0 100644 --- a/internal/provider/resource_gitlab_project.go +++ b/internal/provider/resource_gitlab_project.go @@ -203,6 +203,12 @@ var resourceGitLabProjectSchema = map[string]*schema.Schema{ Type: schema.TypeBool, Optional: true, }, + "printing_merge_request_link_enabled": { + Description: "Show link to create/view merge request when pushing from the command line", + Type: schema.TypeBool, + Optional: true, + Default: true, + }, "packages_enabled": { Description: "Enable packages repository for the project.", Type: schema.TypeBool, @@ -422,6 +428,7 @@ func resourceGitlabProjectSetToState(client *gitlab.Client, d *schema.ResourceDa d.Set("squash_option", project.SquashOption) } d.Set("remove_source_branch_after_merge", project.RemoveSourceBranchAfterMerge) + d.Set("printing_merge_request_link_enabled", project.PrintingMergeRequestLinkEnabled) d.Set("packages_enabled", project.PackagesEnabled) d.Set("pages_access_level", string(project.PagesAccessLevel)) d.Set("mirror", project.Mirror) @@ -458,6 +465,7 @@ func resourceGitlabProjectCreate(ctx context.Context, d *schema.ResourceData, me SharedRunnersEnabled: gitlab.Bool(d.Get("shared_runners_enabled").(bool)), RemoveSourceBranchAfterMerge: gitlab.Bool(d.Get("remove_source_branch_after_merge").(bool)), PackagesEnabled: gitlab.Bool(d.Get("packages_enabled").(bool)), + PrintingMergeRequestLinkEnabled: gitlab.Bool(d.Get("printing_merge_request_link_enabled").(bool)), Mirror: gitlab.Bool(d.Get("mirror").(bool)), MirrorTriggerBuilds: gitlab.Bool(d.Get("mirror_trigger_builds").(bool)), BuildCoverageRegex: gitlab.String(d.Get("build_coverage_regex").(string)), @@ -829,6 +837,10 @@ func resourceGitlabProjectUpdate(ctx context.Context, d *schema.ResourceData, me options.RemoveSourceBranchAfterMerge = gitlab.Bool(d.Get("remove_source_branch_after_merge").(bool)) } + if d.HasChange("printing_merge_request_link_enabled") { + options.PrintingMergeRequestLinkEnabled = gitlab.Bool(d.Get("printing_merge_request_link_enabled").(bool)) + } + if d.HasChange("packages_enabled") { options.PackagesEnabled = gitlab.Bool(d.Get("packages_enabled").(bool)) } diff --git a/internal/provider/resource_gitlab_project_test.go b/internal/provider/resource_gitlab_project_test.go index 50c193bae..47b71b0ea 100644 --- a/internal/provider/resource_gitlab_project_test.go +++ b/internal/provider/resource_gitlab_project_test.go @@ -44,16 +44,17 @@ func TestAccGitlabProject_basic(t *testing.T) { MergeMethod: gitlab.FastForwardMerge, OnlyAllowMergeIfPipelineSucceeds: true, OnlyAllowMergeIfAllDiscussionsAreResolved: true, - SquashOption: gitlab.SquashOptionDefaultOff, - AllowMergeOnSkippedPipeline: false, - Archived: false, // needless, but let's make this explicit - PackagesEnabled: true, - PagesAccessLevel: gitlab.PublicAccessControl, - BuildCoverageRegex: "foo", - IssuesTemplate: "", - MergeRequestsTemplate: "", - CIConfigPath: ".gitlab-ci.yml@mynamespace/myproject", - CIForwardDeploymentEnabled: true, + SquashOption: gitlab.SquashOptionDefaultOff, + AllowMergeOnSkippedPipeline: false, + Archived: false, // needless, but let's make this explicit + PackagesEnabled: true, + PrintingMergeRequestLinkEnabled: true, + PagesAccessLevel: gitlab.PublicAccessControl, + BuildCoverageRegex: "foo", + IssuesTemplate: "", + MergeRequestsTemplate: "", + CIConfigPath: ".gitlab-ci.yml@mynamespace/myproject", + CIForwardDeploymentEnabled: true, } defaultsMainBranch = defaults @@ -91,6 +92,7 @@ func TestAccGitlabProject_basic(t *testing.T) { SharedRunnersEnabled: false, Visibility: gitlab.PublicVisibility, MergeMethod: gitlab.FastForwardMerge, + PrintingMergeRequestLinkEnabled: true, OnlyAllowMergeIfPipelineSucceeds: true, OnlyAllowMergeIfAllDiscussionsAreResolved: true, SquashOption: gitlab.SquashOptionDefaultOn, @@ -482,6 +484,7 @@ func TestAccGitlabProject_willError(t *testing.T) { SharedRunnersEnabled: true, Visibility: gitlab.PublicVisibility, MergeMethod: gitlab.FastForwardMerge, + PrintingMergeRequestLinkEnabled: true, OnlyAllowMergeIfPipelineSucceeds: true, OnlyAllowMergeIfAllDiscussionsAreResolved: true, SquashOption: gitlab.SquashOptionDefaultOff, @@ -589,11 +592,12 @@ func TestAccGitlabProject_transfer(t *testing.T) { MergeMethod: gitlab.NoFastForwardMerge, OnlyAllowMergeIfPipelineSucceeds: false, OnlyAllowMergeIfAllDiscussionsAreResolved: false, - SquashOption: gitlab.SquashOptionDefaultOff, - PackagesEnabled: true, - PagesAccessLevel: gitlab.PrivateAccessControl, - BuildCoverageRegex: "foo", - CIForwardDeploymentEnabled: true, + SquashOption: gitlab.SquashOptionDefaultOff, + PackagesEnabled: true, + PrintingMergeRequestLinkEnabled: true, + PagesAccessLevel: gitlab.PrivateAccessControl, + BuildCoverageRegex: "foo", + CIForwardDeploymentEnabled: true, } resource.Test(t, resource.TestCase{