Commit 9ff844c
authored
Execute
Prior to this change `FactoryBot.lint!` execution can trigger sequential
`FactoryBot.create` calls made within the same test (either Minitest
`test` or RSpec `it` blocks).
This can result in linting violations for records that have
database-level uniqueness constraints.
This commit introduces the private `Linter#in_transaction` method to
wrap the executing block within an [ActiveRecord::Base.transaction][]
block that concludes with raising an [ActiveRecord::Rollback][] error.
After this change, executions no longer contest with database-level
uniqueness constraints.
[ActiveRecord::Base.transaction]: https://edgeapi.rubyonrails.org/classes/ActiveRecord/Transactions/ClassMethods.html#method-i-transaction
[ActiveRecord::Rollback]: https://edgeapi.rubyonrails.org/classes/ActiveRecord/Rollback.htmlFactoryBot.lint! in database transactions (#1726)1 parent 9bf88a5 commit 9ff844c
File tree
3 files changed
+35
-2
lines changed- lib/factory_bot
- spec/acceptance
3 files changed
+35
-2
lines changed| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
1 | 1 | | |
2 | 2 | | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| 6 | + | |
3 | 7 | | |
4 | 8 | | |
5 | 9 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
70 | 70 | | |
71 | 71 | | |
72 | 72 | | |
73 | | - | |
| 73 | + | |
74 | 74 | | |
75 | 75 | | |
76 | 76 | | |
| |||
80 | 80 | | |
81 | 81 | | |
82 | 82 | | |
83 | | - | |
| 83 | + | |
84 | 84 | | |
85 | 85 | | |
86 | 86 | | |
| |||
106 | 106 | | |
107 | 107 | | |
108 | 108 | | |
| 109 | + | |
| 110 | + | |
| 111 | + | |
| 112 | + | |
| 113 | + | |
| 114 | + | |
| 115 | + | |
| 116 | + | |
| 117 | + | |
| 118 | + | |
| 119 | + | |
109 | 120 | | |
110 | 121 | | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
26 | 26 | | |
27 | 27 | | |
28 | 28 | | |
| 29 | + | |
| 30 | + | |
| 31 | + | |
| 32 | + | |
| 33 | + | |
| 34 | + | |
| 35 | + | |
| 36 | + | |
| 37 | + | |
| 38 | + | |
| 39 | + | |
| 40 | + | |
| 41 | + | |
| 42 | + | |
| 43 | + | |
| 44 | + | |
| 45 | + | |
| 46 | + | |
29 | 47 | | |
30 | 48 | | |
31 | 49 | | |
| |||
0 commit comments