Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

server,testutils: remove complexity #108406

Merged
merged 1 commit into from
Aug 10, 2023

Conversation

knz
Copy link
Contributor

@knz knz commented Aug 9, 2023

There is a saying (paraphrasing) that it always takes more work removing unwanted complexity than it takes to add it. This is an example of that.

Prior to this commit, there was an "interesting" propagation of the flag that decides whether or not to define a test tenant for test servers and clusters. In a nutshell, we had:

  • an "input" flag in base.TestServerArgs, which remained mostly immutable
  • a boolean decided once by ShouldStartDefaultTestTenant() either in:
    • serverutils.StartServerOnlyE
    • or testcluster.Start
  • that boolean choice was then propagated to server.testServer via another boolean config flag in server.BaseConfig
  • both the 2nd boolean and the original input flag were then again checked when the time came to do the work (in maybeStartDefaultTestTenant).

Additional complexity was then incurred by the need of TestCluster to make the determination just once (and not once per server).

This commit cuts through all the layers of complexity by simply propagating the choice of ShouldStartDefaultTestTenant() back into the TestServerArgs and only ever reading from that subsequently.

Release note: None
Epic: CRDB-18499

@knz knz requested review from herkolategan and yuzefovich August 9, 2023 01:22
@knz knz requested review from a team as code owners August 9, 2023 01:22
@knz knz requested review from DarrylWong and removed request for a team August 9, 2023 01:22
@cockroach-teamcity
Copy link
Member

This change is Reviewable

@knz knz force-pushed the 20230807-move-ts-start branch 3 times, most recently from a620f46 to 8d7c728 Compare August 9, 2023 02:58
@srosenberg
Copy link
Member

There is a saying (paraphrasing) that it always takes more work removing unwanted complexity than it takes to add it. This is an example of that.

I thought the saying was, "complexity begets complexity"...from which emerges simplicity? :)

Copy link
Member

@yuzefovich yuzefovich left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Nice simplification! :lgtm:

Reviewed 7 of 7 files at r1, all commit messages.
Reviewable status: :shipit: complete! 1 of 0 LGTMs obtained (waiting on @DarrylWong, @herkolategan, and @knz)


pkg/server/testserver.go line 567 at r1 (raw file):

// DefaultTestTenantDisabled is part of the serverutils.TenantControlInterface.
func (ts *testServer) DefaultTestTenantDisabled() bool {

nit: this method is called only in two places, so let's remove it from the interface altogether and, thus, address another TODO.

Update: I think both of those places are now removed.


pkg/testutils/serverutils/test_server_shim.go line 48 at r1 (raw file):

// DefaultTestTenantMessage is a message that is printed when a test is run
// with the default test tenant. This is useful for debugging test failures.
const DefaultTestTenantMessage = `

nit: I think DefaultTestTenantMessage and PreventStartTenantError can now be unexported.


pkg/testutils/testcluster/testcluster.go line 283 at r1 (raw file):

	// Find out how to do the default test tenant. Pick the setting
	// from either the first server with explicit args, or the top-level server args.
	defaultTestTenantOptions := tc.clusterArgs.ServerArgs.DefaultTestTenant

nit: should we have some validation here? Like I'm imagining it'd be unexpected for top-level server args to disable the test tenant whereas server-level args to explicitly ask for it. How about we require that default test tenant options are the same at the top level as well as at all servers, and only ignore unset args and unset default test tenant options (if per-server args are set)?

@knz knz force-pushed the 20230807-move-ts-start branch 2 times, most recently from ed516d0 to 49dfd3f Compare August 9, 2023 20:49
Copy link
Contributor Author

@knz knz left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Reviewable status: :shipit: complete! 1 of 0 LGTMs obtained (waiting on @DarrylWong, @herkolategan, and @yuzefovich)


pkg/server/testserver.go line 567 at r1 (raw file):

Previously, yuzefovich (Yahor Yuzefovich) wrote…

nit: this method is called only in two places, so let's remove it from the interface altogether and, thus, address another TODO.

Update: I think both of those places are now removed.

Done.


pkg/testutils/serverutils/test_server_shim.go line 48 at r1 (raw file):

Previously, yuzefovich (Yahor Yuzefovich) wrote…

nit: I think DefaultTestTenantMessage and PreventStartTenantError can now be unexported.

Done.


pkg/testutils/testcluster/testcluster.go line 283 at r1 (raw file):

Previously, yuzefovich (Yahor Yuzefovich) wrote…

nit: should we have some validation here? Like I'm imagining it'd be unexpected for top-level server args to disable the test tenant whereas server-level args to explicitly ask for it. How about we require that default test tenant options are the same at the top level as well as at all servers, and only ignore unset args and unset default test tenant options (if per-server args are set)?

Good idea, done.

@knz knz force-pushed the 20230807-move-ts-start branch from 49dfd3f to 28cd9e1 Compare August 9, 2023 20:50
Copy link
Collaborator

@herkolategan herkolategan left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I definitely felt the entanglement in this area as well. Great improvement!
Noted that there are some failures on CI around the cluster server arg validation.

Reviewed 3 of 7 files at r1, 4 of 4 files at r2, all commit messages.
Reviewable status: :shipit: complete! 0 of 0 LGTMs obtained (and 1 stale) (waiting on @DarrylWong and @yuzefovich)

@knz knz force-pushed the 20230807-move-ts-start branch from 28cd9e1 to b4e47f8 Compare August 9, 2023 21:30
@knz knz requested review from a team as code owners August 9, 2023 21:30
@knz knz requested a review from sumeerbhola August 9, 2023 21:30
@knz knz force-pushed the 20230807-move-ts-start branch from b4e47f8 to 4f4cee7 Compare August 9, 2023 21:48
@knz
Copy link
Contributor Author

knz commented Aug 9, 2023

Noted that there are some failures on CI around the cluster server arg validation.

Yes these appeared after I added the extra consistency check requested by Yahor. They should be fixed now.

@knz knz force-pushed the 20230807-move-ts-start branch from 4f4cee7 to 4f8045e Compare August 9, 2023 21:51
Copy link
Member

@yuzefovich yuzefovich left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Reviewed 3 of 4 files at r2, 6 of 7 files at r3, 3 of 3 files at r4, 1 of 1 files at r5, all commit messages.
Reviewable status: :shipit: complete! 0 of 0 LGTMs obtained (and 1 stale) (waiting on @DarrylWong and @sumeerbhola)

There is a saying (paraphrasing) that it always takes more work
removing unwanted complexity than it takes to add it. This is an
example of that.

Prior to this commit, there was an "interesting" propagation of the
flag that decides whether or not to define a test tenant for test
servers and clusters. In a nutshell, we had:

- an "input" flag in `base.TestServerArgs`, which remained mostly immutable
- a boolean decided once by `ShouldStartDefaultTestTenant()` either in:
  - `serverutils.StartServerOnlyE`
  - or `testcluster.Start`
- that boolean choice was then propagated to `server.testServer` via
  _another_ boolean config flag in `server.BaseConfig`
- both the 2nd boolean and the original input flag were then again
  checked when the time came to do the work (in `maybeStartDefaultTestTenant`).

Additional complexity was then incurred by the need of `TestCluster`
to make the determination just once (and not once per server).

This commit cuts through all the layers of complexity by simply
propagating the choice of `ShouldStartDefaultTestTenant()` back into
the `TestServerArgs` and only ever reading from that subsequently.

Release note: None
@knz knz force-pushed the 20230807-move-ts-start branch from 4f8045e to 49374d4 Compare August 10, 2023 15:04
@knz knz requested a review from a team as a code owner August 10, 2023 15:04
@knz knz requested a review from a team as a code owner August 10, 2023 15:04
@knz knz requested review from rhu713 and HonoreDB and removed request for a team, sumeerbhola, rhu713 and HonoreDB August 10, 2023 15:04
@knz
Copy link
Contributor Author

knz commented Aug 10, 2023

TFYRs!

bors r=yuzefovich,herkolategan

@craig craig bot merged commit 1f8fa96 into cockroachdb:master Aug 10, 2023
@craig
Copy link
Contributor

craig bot commented Aug 10, 2023

Build succeeded:

@knz knz deleted the 20230807-move-ts-start branch August 10, 2023 17:27
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.

5 participants