-
Notifications
You must be signed in to change notification settings - Fork 1.7k
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
[Bug] Intermittent errors when unit testing versioned models #11139
Comments
@CarrotPapa Thanks for such a nice write-up with detailed listing of your project files, commands, and output 🤩 Intermittent errors are tough to debug! I tried out an example nearly the identical to the one you provided, but I wasn't able to trigger the error. See below for the files I used. I suspect it is some kind of issue related to cached files in your Project files
select 1 as id
select * from {{ ref("table_a") }}
select * from {{ ref("table_a") }}
version: 2
models:
- name: model
latest_version: 1
versions:
- v: 2
defined_in: model_v2
- v: 1
defined_in: model
config:
alias: model
unit_tests:
- name: test_model
model: model
versions:
include:
- 2
given:
- input: ref('table_a')
rows:
- {id: 2}
expect:
rows:
- {id: 2} Ran this command: dbt compile Got this output:
|
Thanks @dbeatty10 for taking a look at the issue. |
I have figured out how to reliably reproduce the intermittent errors. It seems the key is to place the unit tests in a separate directory (e.g.
|
Thanks for this info @CarrotPapa ! After a bit of experimentation, I was able to observe that same parsing error. Read below for details. Suspected root causeI'm guessing that the underlying root cause is the order in which dbt is parsing the files (which is in turn affected by the order in which the filesystem is returning the files, which can be non-deterministic). ReprexCreate these files
select 1 as id
select 1 as id
models:
- name: model
latest_version: 1
versions:
- v: 2
defined_in: model_v2
- v: 1
defined_in: model
config:
alias: model
unit_tests:
- name: test_model
model: model
versions:
include:
- 2
given: []
expect:
rows:
- {id: 1}
Run these commandsStart with these commands to create some empty YAML files: rm -rf models/schema_yml_files
mkdir -p models/schema_yml_files
touch models/schema_yml_files/_1234.yml
touch models/schema_yml_files/_4567.yml Next, we'll put YAML content in each of the files -- one file with the unit test, and the other file with the model versions. Then I'd expect one (and only one!) of the following cat _unit_tests.yml.template > models/schema_yml_files/_1234.yml
cat _models.yml.template > models/schema_yml_files/_4567.yml
dbt compile --no-partial-parse cat _unit_tests.yml.template > models/schema_yml_files/_4567.yml
cat _models.yml.template > models/schema_yml_files/_1234.yml
dbt compile --no-partial-parse For me, the first one gave the error and the second one worked. But for you the order might be different! Either way, it looks to me like we'd need to make a fix so that the dbt parsing is unaffected by the order of the listing from the filesystem. WorkaroundThe following workaround worked for me:
For example, using the project files above, run these commands: rm -rf models/schema_yml_files
mkdir -p models/schema_yml_files
cat _models.yml.template _unit_tests.yml.template > models/schema_yml_files/_properties.yml
dbt compile --no-partial-parse |
Is this a new bug in dbt-core?
Current Behavior
Encountering an intermittent error during unit testing of versioned models. The error resolved after removing the associated unit tests.
Expected Behavior
When it worked, it looks like the following:
Steps To Reproduce
model.sql:
model_v2.sql:
schema.yml:
test_model.yml:
Relevant log output
No response
Environment
Which database adapter are you using with dbt?
bigquery
Additional Context
No response
The text was updated successfully, but these errors were encountered: