fabricks 3.0.6__tar.gz → 3.0.8__tar.gz
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- {fabricks-3.0.6 → fabricks-3.0.8}/PKG-INFO +1 -1
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/cdc/templates/queries/nocdc/update.sql.jinja +1 -2
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/context/utils.py +26 -22
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/core/jobs/gold.py +3 -2
- fabricks-3.0.8/fabricks/core/schedules/diagrams.py +21 -0
- fabricks-3.0.6/fabricks/core/schedules/diagrams.py → fabricks-3.0.8/fabricks/utils/mermaid.py +1 -15
- {fabricks-3.0.6 → fabricks-3.0.8}/pyproject.toml +1 -1
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/fabricksconfig.json +1 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/jobs/job1/test_gold.py +11 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/jobs/job5/test_step.py +27 -2
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/gold/gold/fact/_config.fact.yml +1 -0
- fabricks-3.0.8/tests/integration/runtime/semantic/dim/_config.semantic.yml +8 -0
- fabricks-3.0.8/tests/integration/runtime/semantic/dim/complex_query.sql +122 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/uv.lock +1584 -1583
- {fabricks-3.0.6 → fabricks-3.0.8}/.gitignore +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/.gitkeep +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/.python-version +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/README.md +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/databricks.yml +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/docs/helpers/init.md +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/docs/helpers/job.md +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/docs/helpers/runtime.md +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/docs/helpers/schedule.md +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/docs/helpers/step.md +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/docs/index.md +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/docs/introduction/layers.md +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/docs/introduction/overview.md +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/docs/reference/cdc.md +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/docs/reference/checks-data-quality.md +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/docs/reference/extenders-udfs-parsers.md +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/docs/reference/table-options.md +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/docs/steps/BRONZE.md +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/docs/steps/GOLD.md +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/docs/steps/SILVER.md +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/__init__.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/api/__init__.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/api/cdc/__init__.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/api/cdc/nocdc.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/api/cdc/scd1.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/api/cdc/scd2.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/api/context.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/api/core.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/api/deploy.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/api/exceptions.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/api/extenders.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/api/job_schema.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/api/log.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/api/masks.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/api/metastore/__init__.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/api/metastore/database.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/api/metastore/table.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/api/metastore/view.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/api/notebooks/__init__.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/api/notebooks/cluster.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/api/notebooks/initialize.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/api/notebooks/process.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/api/notebooks/run.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/api/notebooks/schedule.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/api/notebooks/terminate.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/api/parsers.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/api/schedules.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/api/udfs.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/api/utils.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/api/version.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/api/views.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/cdc/__init__.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/cdc/base/__init__.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/cdc/base/_types.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/cdc/base/cdc.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/cdc/base/configurator.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/cdc/base/generator.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/cdc/base/merger.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/cdc/base/processor.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/cdc/cdc.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/cdc/nocdc.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/cdc/scd.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/cdc/scd1.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/cdc/scd2.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/cdc/templates/__init__.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/cdc/templates/ctes/base.sql.jinja +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/cdc/templates/ctes/current.sql.jinja +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/cdc/templates/ctes/deduplicate_hash.sql.jinja +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/cdc/templates/ctes/deduplicate_key.sql.jinja +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/cdc/templates/ctes/rectify.sql.jinja +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/cdc/templates/ctes/slice.sql.jinja +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/cdc/templates/filter.sql.jinja +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/cdc/templates/filters/final.sql.jinja +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/cdc/templates/filters/latest.sql.jinja +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/cdc/templates/filters/update.sql.jinja +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/cdc/templates/macros/bactick.sql.jinja +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/cdc/templates/macros/hash.sql.jinja +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/cdc/templates/merge.sql.jinja +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/cdc/templates/merges/nocdc.sql.jinja +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/cdc/templates/merges/scd1.sql.jinja +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/cdc/templates/merges/scd2.sql.jinja +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/cdc/templates/queries/__init__.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/cdc/templates/queries/context.sql.jinja +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/cdc/templates/queries/final.sql.jinja +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/cdc/templates/queries/nocdc/complete.sql.jinja +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/cdc/templates/queries/scd1.sql.jinja +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/cdc/templates/queries/scd2.sql.jinja +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/cdc/templates/query.sql.jinja +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/context/__init__.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/context/_types.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/context/config/__init__.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/context/config/utils.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/context/log.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/context/runtime.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/context/secret.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/context/spark_session.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/core/__init__.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/core/dags/__init__.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/core/dags/base.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/core/dags/generator.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/core/dags/log.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/core/dags/processor.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/core/dags/run.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/core/dags/terminator.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/core/dags/utils.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/core/extenders.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/core/job_schema.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/core/jobs/__init__.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/core/jobs/base/__init__.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/core/jobs/base/_types.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/core/jobs/base/checker.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/core/jobs/base/configurator.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/core/jobs/base/exception.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/core/jobs/base/generator.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/core/jobs/base/invoker.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/core/jobs/base/job.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/core/jobs/base/processor.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/core/jobs/bronze.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/core/jobs/get_job.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/core/jobs/get_job_conf.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/core/jobs/get_job_id.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/core/jobs/get_jobs.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/core/jobs/get_schedule.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/core/jobs/get_schedules.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/core/jobs/silver.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/core/masks.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/core/parsers/__init__.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/core/parsers/_types.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/core/parsers/base.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/core/parsers/decorator.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/core/parsers/get_parser.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/core/parsers/utils.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/core/schedules/__init__.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/core/schedules/generate.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/core/schedules/get_schedule.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/core/schedules/get_schedules.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/core/schedules/process.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/core/schedules/run.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/core/schedules/terminate.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/core/schedules/views.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/core/steps/__init__.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/core/steps/_types.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/core/steps/base.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/core/steps/get_step.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/core/steps/get_step_conf.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/core/udfs.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/core/views.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/deploy/__init__.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/deploy/masks.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/deploy/notebooks.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/deploy/schedules.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/deploy/tables.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/deploy/udfs.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/deploy/utils.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/deploy/views.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/metastore/README.md +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/metastore/__init__.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/metastore/_types.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/metastore/database.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/metastore/dbobject.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/metastore/pyproject.toml +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/metastore/table.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/metastore/utils.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/metastore/view.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/utils/__init__.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/utils/_types.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/utils/azure_queue.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/utils/azure_table.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/utils/console.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/utils/fdict.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/utils/helpers.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/utils/log.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/utils/path.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/utils/pip.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/utils/pydantic.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/utils/read/__init__.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/utils/read/_types.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/utils/read/read.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/utils/read/read_excel.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/utils/read/read_yaml.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/utils/schema/__init__.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/utils/schema/get_json_schema_for_type.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/utils/schema/get_schema_for_type.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/utils/spark.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/utils/sqlglot.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/utils/write/__init__.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/utils/write/delta.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/fabricks/utils/write/stream.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/format.sh +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/mkdocs.sh +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/mkdocs.yml +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/__init__.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/__init__.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/_types.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/add_missing_modules.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/armageddon.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/compare.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/data/job1/king/2022/01/01/0001/king_202201010001.json +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/data/job1/king/2022/01/02/0001/king_202201020001.json +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/data/job1/king__deletelog/2022/02/01/0001/king_202201010001.json +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/data/job1/prince/2022/01/01/0001/prince_202201010001.json +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/data/job1/princess/2022/01/01/0001/princess_202201010001.json +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/data/job1/queen/2022/01/01/0001/queen_202201010001.json +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/data/job1/queen/2022/01/02/0001/queen_202201020001.json +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/data/job1/queen/2022/01/04/0001/queen_202201040001.json +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/data/job1/queen__deletelog/2022/01/03/0001/queen_202201030001.json +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/data/job1/queen__deletelog/2022/01/04/0001/queen_202201040001.json +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/data/job1/too_many_columns/2022/01/01/0001/sample_202201010001.json +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/data/job10/king/2022/10/01/0001/king_202210010001.json +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/data/job10/king/2022/10/02/0001/king_202210020001.json +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/data/job10/king/2022/10/02/0002/king_202210020002.json +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/data/job10/king/2022/10/03/0001/king_202210030001.json +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/data/job10/queen__deletelog/2022/10/01/0001/queen_202210010001.json +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/data/job11/king/2022/11/01/0001/king_202210010001.json +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/data/job11/king__deletelog/2022/11/01/0001/king_202211010001.json +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/data/job2/king/2022/02/05/0001/king_202202050001.json +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/data/job2/prince__deletelog/2022/02/01/0001/prince_202202010001.json +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/data/job2/princess/2022/02/05/0001/princess_202202050001.json +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/data/job2/queen/2022/02/05/0001/queen_202202050001.json +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/data/job3/king/2022/03/01/001234/king_20220301001234.json +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/data/job3/king__deletelog/2022/03/01/001234/king_20220301001234.json +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/data/job3/queen/2022/03/05/001234/queen_20220305001234.json +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/data/job3/queen/2022/03/06/0001/queen_202203060001.json +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/data/job4/king/2022/04/01/0001/king_202204010001.json +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/data/job4/monarch/2022/04/01/0001/monarch_202204010001.json +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/data/job4/queen/2022/04/01/0001/queen_202204010001.json +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/data/job4/regent/2022/04/01/0001/regent_202204010001.json +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/data/job5/king/2022/05/01/0001/king_202205010001.json +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/data/job5/queen/2022/05/01/0001/queen_202205010001.json +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/data/job6/king/2022/06/01/0001/king_202206010001.json +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/data/job6/queen/2022/06/01/0001/queen_202206010001.json +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/data/job7/king/2022/07/01/0001/king_202207010001.json +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/data/job7/queen/2022/07/01/0001/queen_202207010001.json +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/data/job8/king/2022/08/01/0001/king_202208010001.json +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/data/job8/queen/2022/08/01/0001/queen_202208010001.json +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/data/job9/king/2022/09/01/0001/king_202209010001.json +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/data/job9/king/2022/09/03/0001/king_202209030001.json +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/data/job9/king/2022/09/03/0002/king_202209030002.json +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/data/job9/king/2022/09/08/0001/king_202209080001.json +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/data/job9/king__deletelog/2022/09/02/0001/king_202209020001.json +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/data/job9/king__deletelog/2022/09/04/0001/king_202209040001.json +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/data/job9/king__deletelog/2022/09/04/0005/king_202209040005.json +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/data/job9/king__deletelog/2022/09/04/0009/king_202209040009.json +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/data/job9/queen/2022/09/08/0001/queen_202209080001.json +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/data/job9/queen__deletelog/2022/09/01/0001/queen_202209030001.json +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/expected/gold/scd1/job01.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/expected/gold/scd1/job02.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/expected/gold/scd1/job03.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/expected/gold/scd1/job04.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/expected/gold/scd1/job05.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/expected/gold/scd1/job06.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/expected/gold/scd1/job07.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/expected/gold/scd1/job08.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/expected/gold/scd1/job09.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/expected/gold/scd1/job10.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/expected/gold/scd1/job11.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/expected/gold/scd2/job01.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/expected/gold/scd2/job02.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/expected/gold/scd2/job03.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/expected/gold/scd2/job04.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/expected/gold/scd2/job05.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/expected/gold/scd2/job06.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/expected/gold/scd2/job07.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/expected/gold/scd2/job08.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/expected/gold/scd2/job09.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/expected/gold/scd2/job10.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/expected/gold/scd2/job11.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/expected/silver/scd1/job01.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/expected/silver/scd1/job02.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/expected/silver/scd1/job03.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/expected/silver/scd1/job04.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/expected/silver/scd1/job05.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/expected/silver/scd1/job06.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/expected/silver/scd1/job07.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/expected/silver/scd1/job08.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/expected/silver/scd1/job09.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/expected/silver/scd1/job10.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/expected/silver/scd1/job11.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/expected/silver/scd2/job01.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/expected/silver/scd2/job02.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/expected/silver/scd2/job03.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/expected/silver/scd2/job04.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/expected/silver/scd2/job05.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/expected/silver/scd2/job06.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/expected/silver/scd2/job07.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/expected/silver/scd2/job08.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/expected/silver/scd2/job09.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/expected/silver/scd2/job10.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/expected/silver/scd2/job11.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/init.sh +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/initialize.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/jobs/__init__.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/jobs/job1/__init__.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/jobs/job1/test_cdc.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/jobs/job1/test_check.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/jobs/job1/test_dependency.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/jobs/job1/test_invoke.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/jobs/job1/test_overwrite.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/jobs/job1/test_schedule.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/jobs/job1/test_semantic.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/jobs/job1/test_silver.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/jobs/job2/__init__.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/jobs/job2/test_gold.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/jobs/job2/test_run.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/jobs/job2/test_semantic.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/jobs/job2/test_silver.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/jobs/job3/__init__.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/jobs/job3/test_gold.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/jobs/job3/test_run.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/jobs/job3/test_silver.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/jobs/job4/__init__.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/jobs/job4/test_gold.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/jobs/job4/test_run.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/jobs/job5/__init__.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/reset.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/run.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runjobs.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtests.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/.gitignore +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/__init__.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/bronze/_config.kings.yml +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/bronze/_config.memory.yml +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/bronze/_config.monarchs.yml +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/bronze/_config.princes.yml +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/bronze/_config.princesses.yml +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/bronze/_config.queens.yml +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/bronze/_config.regents.yml +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/fabricks/conf.fabricks.yml +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/fabricks/conf.uc.fabricks.yml +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/fabricks/extenders/__init__.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/fabricks/extenders/add_country.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/fabricks/extenders/drop__cols.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/fabricks/extenders/force_reload.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/fabricks/extenders/monarch.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/fabricks/masks/dummy.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/fabricks/notebooks/add_missing_modules.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/fabricks/notebooks/cluster.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/fabricks/notebooks/initialize.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/fabricks/notebooks/process.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/fabricks/notebooks/run.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/fabricks/notebooks/schedule.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/fabricks/notebooks/terminate.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/fabricks/parsers/__init__.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/fabricks/parsers/delete_log.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/fabricks/parsers/monarch.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/fabricks/requirements.txt +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/fabricks/schedules/schedule.yml +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/fabricks/udfs/__init__.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/fabricks/udfs/addition.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/fabricks/udfs/identity.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/fabricks/udfs/key.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/fabricks/udfs/parse_phone_number.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/fabricks/views/monarch.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/gold/gold/check/_config.check.yml +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/gold/gold/check/count_must_equal.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/gold/gold/check/duplicate_identity.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/gold/gold/check/duplicate_key.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/gold/gold/check/fail.pre_run.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/gold/gold/check/fail.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/gold/gold/check/max_rows.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/gold/gold/check/min_rows.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/gold/gold/check/skip.skip.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/gold/gold/check/skip.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/gold/gold/check/warning.post_run.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/gold/gold/check/warning.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/gold/gold/dim/_config.dim.yml +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/gold/gold/dim/date.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/gold/gold/dim/identity.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/gold/gold/dim/overwrite.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/gold/gold/dim/time.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/gold/gold/fact/add_missing_modules.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/gold/gold/fact/append.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/gold/gold/fact/deduplicate.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/gold/gold/fact/dependency_notebook.ipynb +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/gold/gold/fact/dependency_sql.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/gold/gold/fact/foreign_keys.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/gold/gold/fact/manual.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/gold/gold/fact/masker_and_commenter.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/gold/gold/fact/memory.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/gold/gold/fact/no_drop.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/gold/gold/fact/notebook.ipynb +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/gold/gold/fact/optimize_vacuum.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/gold/gold/fact/option.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/gold/gold/fact/order_duplicate.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/gold/gold/fact/overwrite.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/gold/gold/fact/primary_key.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/gold/gold/fact/udf.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/gold/gold/invoke/_config.invoke.yml +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/gold/gold/invoke/failed_pre_run.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/gold/gold/invoke/notebook.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/gold/gold/invoke/notebook_without_argument.ipynb +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/gold/gold/invoke/notebooks.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/gold/gold/invoke/notebooks_failed_pre_run.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/gold/gold/invoke/post_run/exe.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/gold/gold/invoke/post_run.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/gold/gold/invoke/pre_run/exe.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/gold/gold/invoke/pre_run/exe_2.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/gold/gold/invoke/timedout.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/gold/gold/invoke/timedout_pre_run.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/gold/gold/nocdc/_config.nocdc.yml +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/gold/gold/nocdc/deduplicate.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/gold/gold/nocdc/update.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/gold/gold/scd1/_config.scd1.yml +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/gold/gold/scd1/complete.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/gold/gold/scd1/identity.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/gold/gold/scd1/last_timestamp.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/gold/gold/scd1/memory.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/gold/gold/scd1/special_char.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/gold/gold/scd1/update.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/gold/gold/scd2/_config.scd2.yml +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/gold/gold/scd2/complete.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/gold/gold/scd2/correct_valid_from.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/gold/gold/scd2/last_timestamp.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/gold/gold/scd2/memory.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/gold/gold/scd2/update.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/gold/gold/type_widening/_config.type_widening.yml +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/gold/gold/type_widening/merge.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/gold/gold/type_widening/overwrite.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/gold/transf/fact/_config.transf.yml +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/gold/transf/fact/memory.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/gold/transf/post_run.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/job-schema.json +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/semantic/fact/_config.semantic.yml +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/semantic/fact/job_option.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/semantic/fact/powerbi.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/semantic/fact/schema_drift.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/semantic/fact/step_option.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/semantic/fact/zstd.sql +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/silver/_config.kings_and_queens.yml +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/silver/_config.memory.yml +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/silver/_config.monarchs.yml +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/silver/_config.princes.yml +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/silver/_config.princesses.yml +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/silver/_config.regents.yml +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/uc/bronze/_config.kings.yml +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/uc/bronze/_config.memory.yml +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/uc/bronze/_config.monarchs.yml +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/uc/bronze/_config.princes.yml +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/uc/bronze/_config.princesses.yml +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/uc/bronze/_config.queens.yml +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/runtime/uc/bronze/_config.regents.yml +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/schedule.py +0 -0
- {fabricks-3.0.6 → fabricks-3.0.8}/tests/integration/utils.py +0 -0
|
@@ -16,8 +16,7 @@
|
|
|
16
16
|
{% for output in outputs %} c.`{{ output }}`, {% endfor %}
|
|
17
17
|
from __current c
|
|
18
18
|
left anti join
|
|
19
|
-
{{ parent_cdc }} s on s.__key == c.__key and s.
|
|
20
|
-
{% if has_source %} and s.__source = c.__source {% endif %}
|
|
19
|
+
{{ parent_cdc }} s on s.__key == c.__key {% if has_source %} and s.__source = c.__source {% endif %}
|
|
21
20
|
{% endif %}
|
|
22
21
|
),
|
|
23
22
|
{% else %}
|
|
@@ -4,7 +4,7 @@ import fabricks.context.config as c
|
|
|
4
4
|
import fabricks.context.runtime as r
|
|
5
5
|
|
|
6
6
|
|
|
7
|
-
def pprint_runtime():
|
|
7
|
+
def pprint_runtime(extended: bool = False) -> None:
|
|
8
8
|
print("=" * 60)
|
|
9
9
|
print("FABRICKS RUNTIME CONFIGURATION")
|
|
10
10
|
print("=" * 60)
|
|
@@ -50,27 +50,31 @@ def pprint_runtime():
|
|
|
50
50
|
print("\n🔐 SECURITY:")
|
|
51
51
|
print(f" Secret Scope: {r.SECRET_SCOPE}")
|
|
52
52
|
|
|
53
|
-
|
|
54
|
-
print("
|
|
55
|
-
components = [
|
|
56
|
-
("UDFs", r.PATH_UDFS),
|
|
57
|
-
("Parsers", r.PATH_PARSERS),
|
|
58
|
-
("Extenders", r.PATH_EXTENDERS),
|
|
59
|
-
("Views", r.PATH_VIEWS),
|
|
60
|
-
("Schedules", r.PATH_SCHEDULES),
|
|
61
|
-
]
|
|
53
|
+
print("\n🌐 ADDITIONAL SETTINGS:")
|
|
54
|
+
print(f" Timezone: {r.TIMEZONE}")
|
|
62
55
|
|
|
63
|
-
|
|
64
|
-
|
|
56
|
+
if extended:
|
|
57
|
+
# Component Paths Section
|
|
58
|
+
print("\n🛠️ COMPONENT PATHS:")
|
|
59
|
+
components = [
|
|
60
|
+
("UDFs", r.PATH_UDFS),
|
|
61
|
+
("Parsers", r.PATH_PARSERS),
|
|
62
|
+
("Extenders", r.PATH_EXTENDERS),
|
|
63
|
+
("Views", r.PATH_VIEWS),
|
|
64
|
+
("Schedules", r.PATH_SCHEDULES),
|
|
65
|
+
]
|
|
65
66
|
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
for name, path in sorted(r.PATHS_STORAGE.items()):
|
|
69
|
-
icon = "🏭" if name == "fabricks" else "📊"
|
|
70
|
-
print(f" {icon} {name}: {path.string}")
|
|
67
|
+
for name, path in components:
|
|
68
|
+
print(f" {name}: {path.string}")
|
|
71
69
|
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
print(f"
|
|
70
|
+
# Storage Paths Section
|
|
71
|
+
print("\n📦 STORAGE PATHS:")
|
|
72
|
+
for name, path in sorted(r.PATHS_STORAGE.items()):
|
|
73
|
+
icon = "🏭" if name == "fabricks" else "📊"
|
|
74
|
+
print(f" {icon} {name}: {path.string}")
|
|
75
|
+
|
|
76
|
+
# Runtime Paths Section
|
|
77
|
+
if r.PATHS_RUNTIME:
|
|
78
|
+
print("\n⚡ RUNTIME PATHS:")
|
|
79
|
+
for name, path in sorted(r.PATHS_RUNTIME.items()):
|
|
80
|
+
print(f" 📂 {name}: {path.string}")
|
|
@@ -13,7 +13,7 @@ from fabricks.core.jobs.base.job import BaseJob
|
|
|
13
13
|
from fabricks.core.udfs import is_registered, register_udf
|
|
14
14
|
from fabricks.metastore.view import create_or_replace_global_temp_view
|
|
15
15
|
from fabricks.utils.path import Path
|
|
16
|
-
from fabricks.utils.sqlglot import get_tables
|
|
16
|
+
from fabricks.utils.sqlglot import fix, get_tables
|
|
17
17
|
|
|
18
18
|
|
|
19
19
|
class Gold(BaseJob):
|
|
@@ -68,7 +68,8 @@ class Gold(BaseJob):
|
|
|
68
68
|
|
|
69
69
|
@property
|
|
70
70
|
def sql(self) -> str:
|
|
71
|
-
|
|
71
|
+
sql = self.paths.runtime.get_sql()
|
|
72
|
+
return fix(sql)
|
|
72
73
|
|
|
73
74
|
@deprecated("use sql instead")
|
|
74
75
|
def get_sql(self) -> str:
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
from pyspark.sql import DataFrame
|
|
2
|
+
|
|
3
|
+
|
|
4
|
+
def get_dependencies(name: str) -> DataFrame:
|
|
5
|
+
from fabricks.core.dags import DagGenerator
|
|
6
|
+
|
|
7
|
+
g = DagGenerator(schedule=name)
|
|
8
|
+
return g.get_dependencies()
|
|
9
|
+
|
|
10
|
+
|
|
11
|
+
def get_mermaid_diagram(name: str) -> str:
|
|
12
|
+
from fabricks.utils.mermaid import get_mermaid_diagram as get_diagram
|
|
13
|
+
|
|
14
|
+
df = get_dependencies(name)
|
|
15
|
+
|
|
16
|
+
df = df.withColumnRenamed("ParentId", "parent_id")
|
|
17
|
+
df = df.withColumnRenamed("Parent", "parent")
|
|
18
|
+
df = df.withColumnRenamed("JobId", "job_id")
|
|
19
|
+
df = df.withColumnRenamed("Job", "job")
|
|
20
|
+
|
|
21
|
+
return get_diagram(df)
|
fabricks-3.0.6/fabricks/core/schedules/diagrams.py → fabricks-3.0.8/fabricks/utils/mermaid.py
RENAMED
|
@@ -1,21 +1,7 @@
|
|
|
1
1
|
from pyspark.sql import DataFrame
|
|
2
2
|
|
|
3
3
|
|
|
4
|
-
def
|
|
5
|
-
from fabricks.core.dags import DagGenerator
|
|
6
|
-
|
|
7
|
-
g = DagGenerator(schedule=name)
|
|
8
|
-
return g.get_dependencies()
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
def get_mermaid_diagram(name: str) -> str:
|
|
12
|
-
df = get_dependencies(name)
|
|
13
|
-
|
|
14
|
-
df = df.withColumnRenamed("ParentId", "parent_id")
|
|
15
|
-
df = df.withColumnRenamed("Parent", "parent")
|
|
16
|
-
df = df.withColumnRenamed("JobId", "job_id")
|
|
17
|
-
df = df.withColumnRenamed("Job", "job")
|
|
18
|
-
|
|
4
|
+
def get_mermaid_diagram(df: DataFrame) -> str:
|
|
19
5
|
dependencies = df.select("parent_id", "parent", "job_id", "job").collect()
|
|
20
6
|
|
|
21
7
|
out = "flowchart TD\n"
|
|
@@ -142,3 +142,14 @@ def test_gold_fact_no_drop():
|
|
|
142
142
|
assert False, "drop is allowed while no_drop is set"
|
|
143
143
|
except ValueError:
|
|
144
144
|
assert True, "drop not allowed while no_drop is set"
|
|
145
|
+
|
|
146
|
+
|
|
147
|
+
@pytest.mark.order(131)
|
|
148
|
+
def test_gold_fact_masker_and_commenter():
|
|
149
|
+
df = SPARK.sql("select dummy from gold.fact_masker_and_commenter order by 1 asc")
|
|
150
|
+
|
|
151
|
+
masked_value = df.select("dummy").collect()[0][0]
|
|
152
|
+
assert masked_value == "***", f"dummy {masked_value} <> ***"
|
|
153
|
+
|
|
154
|
+
masked_value = df.select("dummy").collect()[1][0]
|
|
155
|
+
assert masked_value == "2", f"dummy {masked_value} <> 2"
|
|
@@ -10,7 +10,7 @@ DEFAULT_LOGGER.setLevel(ERROR)
|
|
|
10
10
|
|
|
11
11
|
|
|
12
12
|
@pytest.mark.order(501)
|
|
13
|
-
def
|
|
13
|
+
def test_update_dependencies():
|
|
14
14
|
step = get_step("gold")
|
|
15
15
|
|
|
16
16
|
deps, error = step.get_dependencies(loglevel=ERROR)
|
|
@@ -35,7 +35,7 @@ def test_step_gold():
|
|
|
35
35
|
|
|
36
36
|
|
|
37
37
|
@pytest.mark.order(502)
|
|
38
|
-
def
|
|
38
|
+
def test_create_db_objects():
|
|
39
39
|
step = get_step("transf")
|
|
40
40
|
|
|
41
41
|
SPARK.sql("drop view if exists transf.fact_memory")
|
|
@@ -48,3 +48,28 @@ def test_step_transf():
|
|
|
48
48
|
|
|
49
49
|
df = SPARK.sql("select * from fabricks.transf_views")
|
|
50
50
|
assert df.count() == 1, f"{df.count()} view(s) <> 1"
|
|
51
|
+
|
|
52
|
+
|
|
53
|
+
@pytest.mark.order(503)
|
|
54
|
+
def test_update_configurations():
|
|
55
|
+
step = get_step("gold")
|
|
56
|
+
|
|
57
|
+
step.update_configurations()
|
|
58
|
+
|
|
59
|
+
df = SPARK.sql("select * from fabricks.gold_jobs")
|
|
60
|
+
assert df.count() == 51, f"{df.count()} job(s) <> 51"
|
|
61
|
+
|
|
62
|
+
SPARK.sql("update fabricks.gold_jobs set options = null")
|
|
63
|
+
|
|
64
|
+
df = SPARK.sql("select * from fabricks.gold_jobs where options is null")
|
|
65
|
+
assert df.count() == 51, f"{df.count()} job(s) without options <> 51"
|
|
66
|
+
|
|
67
|
+
SPARK.sql("delete from fabricks.gold_jobs where topic == 'scd1'")
|
|
68
|
+
|
|
69
|
+
step.update_configurations()
|
|
70
|
+
|
|
71
|
+
df = SPARK.sql("select * from fabricks.gold_jobs")
|
|
72
|
+
assert df.count() == 51, f"{df.count()} job(s) <> 51"
|
|
73
|
+
|
|
74
|
+
df = SPARK.sql("select * from fabricks.gold_jobs where options is null")
|
|
75
|
+
assert df.count() == 0, f"{df.count()} job(s) without options <> 0"
|
|
@@ -0,0 +1,122 @@
|
|
|
1
|
+
select *
|
|
2
|
+
from
|
|
3
|
+
values
|
|
4
|
+
/*
|
|
5
|
+
|0|Not Royal Stock|
|
|
6
|
+
|1|Royal Stock|
|
|
7
|
+
|2|Rarely Visited|
|
|
8
|
+
|3|Forgotten in Tower|
|
|
9
|
+
|4|Royal Clearance|
|
|
10
|
+
*/
|
|
11
|
+
-- Prince 02 (The Charming Prince)
|
|
12
|
+
('02', 0, 2), -- Not in royal stock -> 2 - available at court
|
|
13
|
+
('02', 1, 3), -- In royal stock -> 3 - available / 1st priority at royal ball
|
|
14
|
+
('02', 2, 2), -- Rarely visited -> 2 - available at court
|
|
15
|
+
('02', 3, 2), -- Forgotten in tower -> 2 - available at court
|
|
16
|
+
('02', 4, 1), -- Royal clearance -> 1 - available (lowest priority, no dancing allowed)
|
|
17
|
+
('02', null, 1),
|
|
18
|
+
-- Princess 03 (The Graceful Princess)
|
|
19
|
+
('03', 0, 2), -- Not in royal stock -> 2 - available at court
|
|
20
|
+
('03', 1, 3), -- In royal stock -> 3 - available
|
|
21
|
+
('03', 2, 2), -- Rarely visited -> 2 - available at court
|
|
22
|
+
('03', 3, 2), -- Forgotten in tower -> 2 - available at court
|
|
23
|
+
('03', 4, 1), -- Royal clearance -> 1 - available (lowest priority, no dancing allowed)
|
|
24
|
+
('03', null, 1),
|
|
25
|
+
-- Prince 04 (The Banished Prince)
|
|
26
|
+
('04', 0, 0), -- n/a -> 0 - banished from kingdom
|
|
27
|
+
('04', 1, 0), -- n/a -> 0 - banished from kingdom
|
|
28
|
+
('04', 2, 0), -- n/a -> 0 - banished from kingdom
|
|
29
|
+
('04', 3, 0), -- n/a -> 0 - banished from kingdom
|
|
30
|
+
('04', 4, 0), -- n/a -> 0 - banished from kingdom
|
|
31
|
+
('04', null, 0),
|
|
32
|
+
-- Princess 05 (The Sleeping Princess)
|
|
33
|
+
('05', 0, 0), -- n/a -> 0 - fast asleep
|
|
34
|
+
('05', 1, 0), -- n/a -> 0 - fast asleep
|
|
35
|
+
('05', 2, 0), -- n/a -> 0 - fast asleep
|
|
36
|
+
('05', 3, 0), -- n/a -> 0 - fast asleep
|
|
37
|
+
('05', 4, 0), -- n/a -> 0 - fast asleep
|
|
38
|
+
('05', null, 0),
|
|
39
|
+
-- Prince 06 (The Retired Prince)
|
|
40
|
+
('06', 0, 0), -- Not available -> 0 - retired to countryside
|
|
41
|
+
('06', 1, 0), -- Not available -> 0 - retired to countryside
|
|
42
|
+
('06', 2, 0), -- Not available -> 0 - retired to countryside
|
|
43
|
+
('06', 3, 0), -- Not available -> 0 - retired to countryside
|
|
44
|
+
('06', 4, 1), -- Royal clearance (Replaced by younger prince) -> 1 - available (lowest priority, no dancing allowed)
|
|
45
|
+
('06', null, 0),
|
|
46
|
+
-- Princess 07 (The Former Court Princess)
|
|
47
|
+
('07', 0, 0), -- Not available -> 0 - left the court
|
|
48
|
+
('07', 1, 0), -- Not available -> 0 - left the court
|
|
49
|
+
('07', 2, 0), -- Not available -> 0 - left the court
|
|
50
|
+
('07', 3, 0), -- Not available -> 0 - left the court
|
|
51
|
+
('07', 4, 1), -- Royal clearance (Duties discontinued) -> 1 - available (lowest priority, no dancing allowed)
|
|
52
|
+
('07', null, 0),
|
|
53
|
+
-- Prince 08 (The Liquidating Prince)
|
|
54
|
+
('08', 0, 0), -- Not available -> 0 - selling the castle
|
|
55
|
+
('08', 1, 0), -- Not available -> 0 - selling the castle
|
|
56
|
+
('08', 2, 0), -- Not available -> 0 - selling the castle
|
|
57
|
+
('08', 3, 0), -- Not available -> 0 - selling the castle
|
|
58
|
+
('08', 4, 1), -- Royal clearance (Estate sale) -> 1 - available (lowest priority, no dancing allowed)
|
|
59
|
+
('08', null, 0),
|
|
60
|
+
-- Princess 09-14 (The Lost Princesses)
|
|
61
|
+
('09', 0, 0), -- n/a -> 0 - lost in the enchanted forest
|
|
62
|
+
('09', 1, 0),
|
|
63
|
+
('09', 2, 0),
|
|
64
|
+
('09', 3, 0),
|
|
65
|
+
('09', 4, 0),
|
|
66
|
+
('09', null, 0),
|
|
67
|
+
('10', 0, 0),
|
|
68
|
+
('10', 1, 0),
|
|
69
|
+
('10', 2, 0),
|
|
70
|
+
('10', 3, 0),
|
|
71
|
+
('10', 4, 0),
|
|
72
|
+
('10', null, 0),
|
|
73
|
+
('11', 0, 0),
|
|
74
|
+
('11', 1, 0),
|
|
75
|
+
('11', 2, 0),
|
|
76
|
+
('11', 3, 0),
|
|
77
|
+
('11', 4, 0),
|
|
78
|
+
('11', null, 0),
|
|
79
|
+
('12', 0, 0),
|
|
80
|
+
('12', 1, 0),
|
|
81
|
+
('12', 2, 0),
|
|
82
|
+
('12', 3, 0),
|
|
83
|
+
('12', 4, 0),
|
|
84
|
+
('12', null, 0),
|
|
85
|
+
('13', 0, 0),
|
|
86
|
+
('13', 1, 0),
|
|
87
|
+
('13', 2, 0),
|
|
88
|
+
('13', 3, 0),
|
|
89
|
+
('13', 4, 0),
|
|
90
|
+
('13', null, 0),
|
|
91
|
+
('14', 0, 0),
|
|
92
|
+
('14', 1, 0),
|
|
93
|
+
('14', 2, 0),
|
|
94
|
+
('14', 3, 0),
|
|
95
|
+
('14', 4, 0),
|
|
96
|
+
('14', null, 0),
|
|
97
|
+
-- Prince 15 (The Service Prince)
|
|
98
|
+
('15', 0, 0), -- Not available -> 0 - in royal service elsewhere
|
|
99
|
+
('15', 1, 0), -- Not available -> 0 - in royal service elsewhere
|
|
100
|
+
('15', 2, 0), -- Not available -> 0 - in royal service elsewhere
|
|
101
|
+
('15', 3, 0), -- Not available -> 0 - in royal service elsewhere
|
|
102
|
+
('15', 4, 1), -- Royal clearance (Special service) -> 1 - available (lowest priority, no dancing allowed)
|
|
103
|
+
('15', null, 0),
|
|
104
|
+
-- Princes 20, 30, 40 (The Distant Princes)
|
|
105
|
+
('20', 0, 0),
|
|
106
|
+
('20', 1, 0),
|
|
107
|
+
('20', 2, 0),
|
|
108
|
+
('20', 3, 0),
|
|
109
|
+
('20', 4, 0),
|
|
110
|
+
('20', null, 0),
|
|
111
|
+
('30', 0, 0),
|
|
112
|
+
('30', 1, 0),
|
|
113
|
+
('30', 2, 0),
|
|
114
|
+
('30', 3, 0),
|
|
115
|
+
('30', 4, 0),
|
|
116
|
+
('30', null, 0),
|
|
117
|
+
('40', 0, 0),
|
|
118
|
+
('40', 1, 0),
|
|
119
|
+
('40', 2, 0),
|
|
120
|
+
('40', 3, 0),
|
|
121
|
+
('40', 4, 0),
|
|
122
|
+
('40', null, 0) as royal_court_status(royal_id, crown_jewels_status_id, royal_availability)
|