databricks-cli/bundle/tests/workflow_and_pipeline_test.go

50 lines
1.7 KiB
Go
Raw Normal View History

2022-11-18 10:12:24 +00:00
package config_tests
import (
"testing"
"github.com/stretchr/testify/assert"
"github.com/stretchr/testify/require"
)
func TestJobAndPipelineDevelopment(t *testing.T) {
2022-12-01 08:35:21 +00:00
b := loadEnvironment(t, "./workflow_and_pipeline", "development")
assert.Len(t, b.Config.Resources.Workflows, 0)
assert.Len(t, b.Config.Resources.Pipelines, 1)
2022-11-18 10:12:24 +00:00
p := b.Config.Resources.Pipelines["nyc_taxi_pipeline"]
2022-11-18 10:12:24 +00:00
assert.True(t, p.Development)
require.Len(t, p.Libraries, 1)
assert.Equal(t, "./dlt/nyc_taxi_loader", p.Libraries[0].Notebook.Path)
assert.Equal(t, "nyc_taxi_development", p.Target)
}
func TestJobAndPipelineStaging(t *testing.T) {
2022-12-01 08:35:21 +00:00
b := loadEnvironment(t, "./workflow_and_pipeline", "staging")
assert.Len(t, b.Config.Resources.Workflows, 0)
assert.Len(t, b.Config.Resources.Pipelines, 1)
2022-11-18 10:12:24 +00:00
p := b.Config.Resources.Pipelines["nyc_taxi_pipeline"]
2022-11-18 10:12:24 +00:00
assert.False(t, p.Development)
require.Len(t, p.Libraries, 1)
assert.Equal(t, "./dlt/nyc_taxi_loader", p.Libraries[0].Notebook.Path)
assert.Equal(t, "nyc_taxi_staging", p.Target)
}
func TestJobAndPipelineProduction(t *testing.T) {
2022-12-01 08:35:21 +00:00
b := loadEnvironment(t, "./workflow_and_pipeline", "production")
assert.Len(t, b.Config.Resources.Workflows, 1)
assert.Len(t, b.Config.Resources.Pipelines, 1)
2022-11-18 10:12:24 +00:00
p := b.Config.Resources.Pipelines["nyc_taxi_pipeline"]
2022-11-18 10:12:24 +00:00
assert.False(t, p.Development)
require.Len(t, p.Libraries, 1)
assert.Equal(t, "./dlt/nyc_taxi_loader", p.Libraries[0].Notebook.Path)
assert.Equal(t, "nyc_taxi_production", p.Target)
2022-12-01 08:35:21 +00:00
j := b.Config.Resources.Workflows["pipeline_schedule"]
2022-11-18 10:12:24 +00:00
assert.Equal(t, "Daily refresh of production pipeline", j.Name)
require.Len(t, j.Tasks, 1)
assert.NotEmpty(t, j.Tasks[0].PipelineTask.PipelineId)
}