Skip to content
New issue

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

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

Already on GitHub? # to your account

Adds a small test to catch issues with deadlocks #5171

Merged
merged 2 commits into from
Mar 27, 2023

Conversation

davidporter-id-au
Copy link
Member

It's quite easy to call the getters on tasks in this function and cause a deadlock. Ensuring complete coverage on this branch to prevent this.

Comment on lines +270 to +281
func (s *taskSuite) TestHandleErr_ErrMaxAttempts() {
taskBase := s.newTestTask(func(task Info) (bool, error) {
return true, nil
}, nil)

taskBase.criticalRetryCount = func(i ...dynamicconfig.FilterOption) int { return 0 }
s.mockTaskInfo.EXPECT().GetTaskType().Return(0)
assert.NotPanics(s.T(), func() {
taskBase.HandleErr(errors.New("err"))
})
}

Copy link
Member

Choose a reason for hiding this comment

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

Since a deadlock won't panic, I've done this in the past:

done := make(chan struct{})
go func() {
  defer close(done)
  deadlocky()
}()
select {
case <-done:
case <-time.After(time.Second): t.Error("timed out == deadlock")
}

fast enough to be practical, without waiting for a full minute or whatever for the normal whole-package test timeout.

Copy link
Member Author

Choose a reason for hiding this comment

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

while I appreciate that makes for a better performing test, it... feels slightly overspecialised with the benefit of hindsight to look exclusively for deadlocks, rather than just checking the path entirely (though, I suppose it would catch a panic all the same).

It looks like there'll be a new testing.T method SetTimeout(d time.Duration) coming soon which should do exactly this and - imho, is a lot less noisy (golang/go#48157)

I don't feel super strongly about it, but I'm wary about one-off testing infra setups such as this in that their complexity might dissuade people to maintain / think about them

Copy link
Member

Choose a reason for hiding this comment

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

SetTimeout would be kinda nice, yea.

I mean more that this wasn't a panic symptom, and "does not panic" on its own is not all that useful of an assertion anyway, since a panicking test is already a test failure. The fact that it's in use seems to imply there's something panic-sensitive about the code in question, and AFAIK there is not.

@coveralls
Copy link

Pull Request Test Coverage Report for Build 01871f21-31ef-46ee-afd1-732d9cae568d

  • 0 of 0 changed or added relevant lines in 0 files are covered.
  • 128 unchanged lines in 11 files lost coverage.
  • Overall coverage decreased (-0.04%) to 57.075%

Files with Coverage Reduction New Missed Lines %
common/membership/hashring.go 2 83.54%
common/task/weightedRoundRobinTaskScheduler.go 2 89.12%
common/util.go 2 52.31%
service/matching/matcher.go 2 91.46%
service/history/task/fetcher.go 3 91.75%
service/history/task/transfer_standby_task_executor.go 4 87.66%
common/persistence/statsComputer.go 6 93.57%
common/persistence/serialization/parser.go 12 62.41%
common/persistence/serialization/thrift_decoder.go 12 53.06%
common/persistence/sql/workflowStateMaps.go 31 81.25%
Totals Coverage Status
Change from base Build 0186f1b3-9b0c-4754-b0ff-0eb624d0ee79: -0.04%
Covered Lines: 85223
Relevant Lines: 149317

💛 - Coveralls

Copy link
Member

@Groxx Groxx left a comment

Choose a reason for hiding this comment

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

useful test either way, comments are just comments and not in any way meant as a requirement :)

@davidporter-id-au davidporter-id-au merged commit 7b281c2 into master Mar 27, 2023
@davidporter-id-au davidporter-id-au deleted the bugfix/add-small-test-for-deadlock-safety branch March 27, 2023 17:38
davidporter-id-au added a commit that referenced this pull request Mar 30, 2023
commit 9d01035
Author: allenchen2244 <102192478+allenchen2244@users.noreply.github.com>
Date:   Wed Mar 29 20:50:38 2023 -0700

    large workflow hot shard detection (#5166)

    Metrics for large workflows

commit dd51c53
Author: David Porter <david.porter@uber.com>
Date:   Wed Mar 29 18:30:06 2023 -0700

    fix build (#5180)

commit 7b281c2
Author: David Porter <david.porter@uber.com>
Date:   Mon Mar 27 10:38:37 2023 -0700

    Adds a small test to catch issues with deadlocks (#5171)

    * Adds a small test to catch issues with deadlocks

commit f1e2476
Author: sonpham96 <sonpham1996@gmail.com>
Date:   Sat Mar 18 05:32:01 2023 +0700

    Upgrade Golang base image to 1.18 to remediate CVEs (#5035)

    Co-authored-by: David Porter <david.porter@uber.com>

commit 1519ace
Author: charlese-instaclustr <76502507+charlese-instaclustr@users.noreply.github.com>
Date:   Fri Mar 17 22:11:27 2023 +0000

    Fix type validation in configstore DC client value updating (#5110)

    * Remove misleading type check, Add more detailed log message

    * removing debugging logging

    * Handle nil update edge case

    ---------

    Co-authored-by: allenchen2244 <102192478+allenchen2244@users.noreply.github.com>
    Co-authored-by: Zijian <Shaddoll@users.noreply.github.com>

commit a3e2774
Author: charlese-instaclustr <76502507+charlese-instaclustr@users.noreply.github.com>
Date:   Fri Mar 17 19:02:40 2023 +0000

    Add Canary TLS support (#5086)

    * add support for TLS connections by Canary, add development config for Canary with TLS

    * update README to include new config option

    * remove testing config

    ---------

    Co-authored-by: David Porter <david.porter@uber.com>
    Co-authored-by: Shijie Sheng <shengs@uber.com>
    Co-authored-by: Zijian <Shaddoll@users.noreply.github.com>

commit ff4eab2
Author: Shijie Sheng <shengs@uber.com>
Date:   Thu Mar 16 20:10:54 2023 -0700

    [history] more cautious in deciding domain state to make decisions on dropping queued tasks (#5164)

    What changed?

    When domain cache returned entity not found error, don't drop queued tasks to be more conservative.

    Why?

    In cases when the cache is dubious, we shouldn't drop the queued tasks.

commit 55a8d93
Author: neil-xie <104041627+neil-xie@users.noreply.github.com>
Date:   Thu Mar 16 14:18:35 2023 -0700

    Add Pinot docker files, table config and schema (#5163)

    * Initial checkin for pinot config files

commit 1304570
Author: Mantas Šidlauskas <mantass@netapp.com>
Date:   Thu Mar 16 15:20:29 2023 +0200

    Set poll interval for filebased dynamic config if not set (#5160)

    * Set poll interval for filebased dynamic config if not set

    * update unit test

commit 42a14b1
Author: Mantas Šidlauskas <mantass@netapp.com>
Date:   Thu Mar 16 10:49:21 2023 +0200

    Elasticsearch: reduce code duplication (#5137)

    * Elasticsearch: reduce code duplication

    * address comments

    ---------

    Co-authored-by: Zijian <Shaddoll@users.noreply.github.com>

commit cbf0d14
Author: bowen xiao <xbowen@uber.com>
Date:   Wed Mar 15 10:19:34 2023 -0700

    fix samples documentation (#5088)

commit ba19a29
Author: Mantas Šidlauskas <mantass@netapp.com>
Date:   Wed Mar 15 12:52:29 2023 +0200

    Add ShardID to valid attributes (#5161)

commit a25cba8
Author: Mantas Šidlauskas <mantass@netapp.com>
Date:   Wed Mar 15 10:56:50 2023 +0200

    ES: single interface for different ES/OpenSearch versions (#5158)

    * ES: single interface for different ES/OpenSearch versions

    * make fmt

commit e3ac246
Author: Ketsia <115650494+ketsiambaku@users.noreply.github.com>
Date:   Tue Mar 14 12:47:40 2023 -0700

    added logging with workflow/domain tags (#5159)

commit 9581488
Author: Ketsia <115650494+ketsiambaku@users.noreply.github.com>
Date:   Mon Mar 13 16:56:45 2023 -0700

    Consistent query pershard metric (#5143)

    * added and update consistent query per shard metric

    * testing pershard metric

    * move sample logger into persistence metric client for cleaness

    * fix test

    * fix lint

    * fix test again

    * fix lint

    * sample logging with workflowid tag

    * added domain tag to logger

    * metric completed

    * addressing comments

    * fix lint

    * Revert "fix lint"

    This reverts commit 1e96944.

    * fix lint second attempt

    ---------

    Co-authored-by: Allen Chen <allenchen2244@uber.com>
# for free to join this conversation on GitHub. Already have an account? # to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants