Defect #29838
closedTime logging via commit message does not work when the configured activity has been overridden on the project level
Added by Jens Krämer about 6 years ago. Updated over 3 years ago.
0%
Description
This happened with a client at Planio, we came up with the attached patch which fixes the problem by looking up the activity in the activities of the associated issues' project. Test case included to illustrate the problem.
The second patch is just a small refactoring which moves the activity finder to the Project model.
Files
0001-fix-logging-time-via-a-commit-message-for-project-sp.patch (4.08 KB) 0001-fix-logging-time-via-a-commit-message-for-project-sp.patch | revised and squashed patch | Jens Krämer, 2020-02-11 07:45 | |
0002-Fix-Rubocop-offense-Rails-FindBy-Use-find_by-instead.patch (829 Bytes) 0002-Fix-Rubocop-offense-Rails-FindBy-Use-find_by-instead.patch | Marius BĂLTEANU, 2020-02-11 09:20 |
Updated by Jens Krämer about 6 years ago
- File 0002-small-refactoring-moves-the-method-to-find-the-activ.patch added
updated version of the second patch, better method name to match the setting
Updated by Go MAEDA about 6 years ago
- Target version set to Candidate for next major release
Updated by Go MAEDA about 6 years ago
- Target version changed from Candidate for next major release to 4.1.0
Updated by Go MAEDA over 5 years ago
- Status changed from New to Needs feedback
The test fails in my environment.
Failure: ChangesetTest#test_ref_keywords_any_with_timelog [test/unit/changeset_test.rb:142]: Expected false to be truthy. bin/rails test test/unit/changeset_test.rb:106
Updated by Go MAEDA about 5 years ago
- Target version changed from 4.1.0 to Candidate for next major release
Removing from 4.1.0 because the test fails.
Updated by Jens Krämer almost 5 years ago
I just applied both patches to current master and all changeset tests pass. Could you please retry / post some logs?
Updated by Marius BĂLTEANU almost 5 years ago
- File deleted (
0002-small-refactoring-moves-the-method-to-find-the-activ.patch)
Updated by Marius BĂLTEANU almost 5 years ago
Jens Krämer wrote:
I just applied both patches to current master and all changeset tests pass. Could you please retry / post some logs?
I've added your patches to my Gitlab CI instance used by me to run the tests and it fails only on MySQL: https://gitlab.com/redmine-org/redmine/-/jobs/431381873
Also, the patches introduce a new Rubocop violation that should be fixed: https://gitlab.com/redmine-org/redmine/-/jobs/431381872
You can see the pipeline here: https://gitlab.com/redmine-org/redmine/pipelines/116431745
Updated by Jens Krämer almost 5 years ago
thats really interesting as I ran my tests against MySQL (5.6) as well. can i see the exact environment in terms of ruby / mysql version somewhere on gitlab?
Updated by Marius BĂLTEANU almost 5 years ago
Jens Krämer wrote:
Yes, you can see inthats really interesting as I ran my tests against MySQL (5.6) as well. can i see the exact environment in terms of ruby / mysql version somewhere on gitlab?
.gitlab-ci.yml
:
- ruby version: https://gitlab.com/redmine-org/redmine/-/blob/feature/29838/.gitlab-ci.yml#L1
- mysql version: https://gitlab.com/redmine-org/redmine/-/blob/feature/29838/.gitlab-ci.yml#L18
- postgres version: https://gitlab.com/redmine-org/redmine/-/blob/feature/29838/.gitlab-ci.yml#L26
I use MySQL 5.7 because the same version is used also by the CI system on redmine.org, see Continuous_integration.
Updated by Jens Krämer almost 5 years ago
- File 0001-fix-logging-time-via-a-commit-message-for-project-sp.patch 0001-fix-logging-time-via-a-commit-message-for-project-sp.patch added
turns out it did not have anything to do with the MySQL version, it was just a race condition in the Changeset test suite due to the commit_logtime_activity_id
setting sometimes being set from a previous test case. The attached combined patch fixes that and replaces all previous patches.
Updated by Marius BĂLTEANU almost 5 years ago
- File 0002-Fix-Rubocop-offense-Rails-FindBy-Use-find_by-instead.patch 0002-Fix-Rubocop-offense-Rails-FindBy-Use-find_by-instead.patch added
- Status changed from Needs feedback to New
- Target version changed from Candidate for next major release to 4.2.0
Jens Krämer wrote:
turns out it did not have anything to do with the MySQL version, it was just a race condition in the Changeset test suite due to the
commit_logtime_activity_id
setting sometimes being set from a previous test case. The attached combined patch fixes that and replaces all previous patches.
All tests pass now with the attached patch that fixes a Rubocop offense: https://gitlab.com/redmine-org/redmine/pipelines/116780713
Updated by Marius BĂLTEANU almost 5 years ago
- File deleted (
0002-small-refactoring-moves-the-method-to-find-the-activ.patch)
Updated by Marius BĂLTEANU almost 5 years ago
- File deleted (
0001-fix-logging-time-via-a-commit-message-for-project-sp.patch)
Updated by Go MAEDA almost 5 years ago
- Status changed from New to Closed
- Assignee set to Go MAEDA
Committed the patches. Thank you for detecting and fixing this issue.
Updated by Marius BĂLTEANU over 3 years ago
- Subject changed from time logging via commit message does not work when the configured activity has been overridden on the project level to Time logging via commit message does not work when the configured activity has been overridden on the project level
Updated by Go MAEDA over 3 years ago
- Tracker changed from Patch to Defect
- Resolution set to Fixed