Skip to content

[FEAT] Add support for Enterprise Cost Centers#3482

Open
timja wants to merge 40 commits into
integrations:mainfrom
timja:cost-centers
Open

[FEAT] Add support for Enterprise Cost Centers#3482
timja wants to merge 40 commits into
integrations:mainfrom
timja:cost-centers

Conversation

@timja

@timja timja commented Jun 10, 2026

Copy link
Copy Markdown

Resubmission of #3000

Thanks to vmvarela for the initial contribution.

I've resolved conflicts and re-run the tests:

❯ make testacc TESTARGS="-run TestAccGithubEnterpriseCostCenter"
==> Running acceptance tests on branch: 🌿 cost-centers 🌿...
TF_ACC=1 CGO_ENABLED=0 go test ./github/... -v -run '^TestAcc'  -run TestAccGithubEnterpriseCostCenter -timeout 120m -count=1
=== RUN   TestAccGithubEnterpriseCostCenterDataSource
--- PASS: TestAccGithubEnterpriseCostCenterDataSource (9.31s)
=== RUN   TestAccGithubEnterpriseCostCentersDataSource
--- PASS: TestAccGithubEnterpriseCostCentersDataSource (9.29s)
=== RUN   TestAccGithubEnterpriseCostCenterOrganizations
=== RUN   TestAccGithubEnterpriseCostCenterOrganizations/manages_organization_assignments_without_error
--- PASS: TestAccGithubEnterpriseCostCenterOrganizations (12.88s)
    --- PASS: TestAccGithubEnterpriseCostCenterOrganizations/manages_organization_assignments_without_error (12.88s)
=== RUN   TestAccGithubEnterpriseCostCenterRepositories
=== RUN   TestAccGithubEnterpriseCostCenterRepositories/manages_repository_assignments_without_error
--- PASS: TestAccGithubEnterpriseCostCenterRepositories (13.48s)
    --- PASS: TestAccGithubEnterpriseCostCenterRepositories/manages_repository_assignments_without_error (13.48s)
=== RUN   TestAccGithubEnterpriseCostCenter
=== RUN   TestAccGithubEnterpriseCostCenter/creates_cost_center_without_error
=== RUN   TestAccGithubEnterpriseCostCenter/updates_cost_center_name_without_error
=== RUN   TestAccGithubEnterpriseCostCenter/imports_cost_center_without_error
--- PASS: TestAccGithubEnterpriseCostCenter (26.23s)
    --- PASS: TestAccGithubEnterpriseCostCenter/creates_cost_center_without_error (6.30s)
    --- PASS: TestAccGithubEnterpriseCostCenter/updates_cost_center_name_without_error (11.62s)
    --- PASS: TestAccGithubEnterpriseCostCenter/imports_cost_center_without_error (8.31s)
=== RUN   TestAccGithubEnterpriseCostCenterUsers
=== RUN   TestAccGithubEnterpriseCostCenterUsers/manages_user_assignments_without_error
--- PASS: TestAccGithubEnterpriseCostCenterUsers (13.28s)
    --- PASS: TestAccGithubEnterpriseCostCenterUsers/manages_user_assignments_without_error (13.28s)
PASS
ok      github.com/integrations/terraform-provider-github/v6/github     85.019s

Resolves #2739


Before the change?

  • No support for enterprise cost centers resources or data

After the change?

  • Two new resources and data sources (github_enterprise_cost_center and github_enterprise_cost_centers)

If you would prefer I'm happy to split out the PR for easier review

NOTE: This API (billing) has no support for APP or fine-grained tokens. 😢

Pull request checklist

  • Schema migrations have been created if needed (example)
  • Tests for the changes have been added (for bug fixes / features)
  • Docs have been reviewed and added / updated if needed (for bug fixes / features)

Does this introduce a breaking change?

Please see our docs on breaking changes to help!

  • Yes
  • No

github-actions Bot and others added 30 commits April 11, 2026 19:20
Add utility functions needed for enterprise cost center resources:
- errIs404(): check if error is a GitHub 404 Not Found response
- errIsRetryable(): check if error is retryable (409, 5xx)
- expandStringSet(): convert schema.Set to []string
- chunkStringSlice(): split slice into chunks for batching
Add util_enterprise_cost_center.go with helper functions for managing
cost center assignments with proper retry logic and batching support.
Manages GitHub Enterprise cost center entities (create, read, update, archive).

Includes:
- Resource implementation with CRUD operations
- Acceptance tests
- Documentation
Authoritative management of user assignments to cost centers.

Includes:
- Resource implementation with batched add/remove operations
- Acceptance tests
- Documentation
…esource

Authoritative management of organization assignments to cost centers.

Includes:
- Resource implementation with batched add/remove operations
- Acceptance tests
- Documentation
…source

Authoritative management of repository assignments to cost centers.

Includes:
- Resource implementation with batched add/remove operations
- Acceptance tests
- Documentation
Add two data sources:
- github_enterprise_cost_center: retrieve a cost center by ID
- github_enterprise_cost_centers: list cost centers with optional state filter

Includes:
- Data source implementations
- Acceptance tests
- Documentation
- Register 4 resources in provider.go:
  - github_enterprise_cost_center
  - github_enterprise_cost_center_users
  - github_enterprise_cost_center_organizations
  - github_enterprise_cost_center_repositories
- Register 2 data sources in provider.go:
  - github_enterprise_cost_center
  - github_enterprise_cost_centers
- Add navigation links in website/github.erb

T_EDITOR=true git rebase --continue
t status
Add example Terraform configuration demonstrating how to:
- Create a cost center
- Assign users, organizations, and repositories
- Use data sources to query cost centers
Update import paths from go-github/v81 to go-github/v82 to match
the current version in upstream/main.
Co-authored-by: Timo Sand <timo.sand@iki.fi>
Remove expandStringSet from util.go and replace usages with direct
expandStringList(set.List()) calls. The function was unnecessary since
schema.Set from d.Get() is never nil.

Resolves PR comments integrations#1-2.
Move the archived/deleted state check from Update to Read function.
If the cost center is archived (deleted), it will be removed from
Terraform state during Read rather than blocking updates.

Resolves PR comment integrations#3.
Split resourceGithubEnterpriseCostCenterUsersCreateOrUpdate into
separate Create and Update functions. Create only adds users,
Update handles the full diff. Both return nil instead of calling Read.

Resolves PR comments integrations#4-5.
Split resourceGithubEnterpriseCostCenterOrganizationsCreateOrUpdate into
separate Create and Update functions. Create only adds organizations,
Update handles the full diff. Both return nil instead of calling Read.

Resolves PR comments integrations#6-7.
Split resourceGithubEnterpriseCostCenterRepositoriesCreateOrUpdate into
separate Create and Update functions. Create only adds repositories,
Update handles the full diff. Both return nil instead of calling Read.

Resolves PR comments integrations#8-9.
…tions

The API returns type strings as 'User', 'Org', and 'Repo' but the tests
were checking for lowercase 'user', 'organization', and 'repository'.
This fix ensures CheckDestroy properly detects remaining assignments.
Add CostCenterResourceType constants (User, Org, Repo) to avoid
magic strings throughout the codebase. This prevents typos and
makes the code more maintainable.

Addresses review feedback from @deiga.
Replace terraform-plugin-sdk/v2 test imports with terraform-plugin-testing
to fix flag redefinition conflict ('sweep' flag registered twice).
This aligns cost center tests with the rest of the codebase.
Keep chunkStringSlice(items, maxSize) generic in util.go to avoid coupling with cost-center-specific constants.

Add nolint:unparam with explicit rationale because current call sites pass the same value, while preserving future reuse for other resources.
The import function now calls GetCostCenter to populate the 'name'
field from the API response. Without this, the Required 'name' field
would be empty after import, causing recreate churn on the next plan.

Addresses review comment from @stevehipwell.
Sub-resources (_users, _organizations, _repositories) now use a simple
cost_center_id as their Terraform ID, consistent with the main
github_enterprise_cost_center resource.

Also moves d.SetId() to after the API call succeeds, preventing
corrupt state if the add-resources call fails.

Tests updated to use ImportStateIdPrefix and read attributes from
state instead of parsing the now-simple ID.

Addresses review comments from @stevehipwell.
Before adding resources to a cost center, check via API whether
the cost center already has resources of the managed type assigned.
If so, return an error asking the user to import or remove them
manually. This prevents silently clobbering pre-existing assignments.
vmvarela and others added 10 commits April 11, 2026 19:20
Replace the two-map diff (currentX + desiredX) with a single map
where false=remove and true=keep. Desired items not in the map are
added. This is shorter and avoids constructing a second map.
Instead of reading resource names from Terraform state (which may be
stale or incomplete), Delete now calls GetCostCenter to fetch the
current list of resources of the managed type from the API and removes
them all. Also handles 404 gracefully (cost center already gone).
The cost center sub-resources (organizations, repositories, users)
were registered in provider.go and had docs, but were accidentally
omitted from the website sidebar navigation.
The modernize/newexpr rule incorrectly suggests replacing github.Ptr(x)
with new(x), but new() takes a type not an expression — the auto-fix
generates invalid Go code. Exclude this specific rule pattern.
…n404AndSwallow304OtherwiseReturnError helper
@github-actions

Copy link
Copy Markdown

👋 Hi, and thank you for this contribution!

This repo is maintained by GitHub and community members on a best-effort basis. We'll get to this as soon as we can.

You can help us prioritize by joining the discussion on open issues and PRs, sharing details on the changes you need, and reviewing other contributions.


🤖 This is an automated message.

@timja timja changed the title cost centers [FEAT] Add support for Enterprise Cost Centers Jun 10, 2026
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

[FEAT]: Add support for Enterprise billing resources

2 participants