From 63dc967aa79df2ebfff3f7a34c39351284c51bc7 Mon Sep 17 00:00:00 2001 From: Vadim Voitenko <74241416+wwoytenko@users.noreply.github.com> Date: Sat, 16 Nov 2024 23:16:52 +0200 Subject: [PATCH] fix: Fixed a bug where a subset query was not generated when provided A problems appears after RuntimeContext refactoring Covered with regression --- docs/overrides/main.html | 2 +- docs/release_notes/greenmask_0_2_5.md | 21 +++++++++ internal/db/postgres/context/context.go | 28 +++++++----- internal/db/postgres/context/context_test.go | 47 ++++++++++++++++++++ mkdocs.yml | 1 + 5 files changed, 86 insertions(+), 13 deletions(-) create mode 100644 docs/release_notes/greenmask_0_2_5.md diff --git a/docs/overrides/main.html b/docs/overrides/main.html index a485ec96..b8053afc 100644 --- a/docs/overrides/main.html +++ b/docs/overrides/main.html @@ -1,7 +1,7 @@ {% extends "base.html" %} {% block announce %} - A new version 0.2.4 (2024.11.16) is released + A new version 0.2.5 (2024.11.16) is released {% endblock %} {% block outdated %} diff --git a/docs/release_notes/greenmask_0_2_5.md b/docs/release_notes/greenmask_0_2_5.md new file mode 100644 index 00000000..866c0631 --- /dev/null +++ b/docs/release_notes/greenmask_0_2_5.md @@ -0,0 +1,21 @@ +# Greenmask 0.2.5 + +This release introduces bug fixes. + +## Changes + +* Fixed a bug where a subset query was not generated when provided [#247](https://github.com/GreenmaskIO/greenmask/pull/247). + + +#### Full Changelog: [v0.2.4...v0.2.5](https://github.com/GreenmaskIO/greenmask/compare/v0.2.4...v0.2.5) + +## Links + +Feel free to reach out to us if you have any questions or need assistance: + +* [Greenmask Roadmap](https://github.com/orgs/GreenmaskIO/projects/6) +* [Email](mailto:support@greenmask.io) +* [Twitter](https://twitter.com/GreenmaskIO) +* [Telegram](https://t.me/greenmask_community) +* [Discord](https://discord.gg/tAJegUKSTB) +* [DockerHub](https://hub.docker.com/r/greenmask/greenmask) diff --git a/internal/db/postgres/context/context.go b/internal/db/postgres/context/context.go index 39b02a97..ccee115a 100644 --- a/internal/db/postgres/context/context.go +++ b/internal/db/postgres/context/context.go @@ -91,23 +91,13 @@ func NewRuntimeContext( vr = nil } + // Build graph of Tables graph, err := subset.NewGraph(ctx, tx, slices.Clone(tables), vr) if err != nil { return nil, fmt.Errorf("error creating graph: %w", err) } - if hasSubset(tables) { - // If table has subset the restoration must be in the topological order - // The Tables must be dumped one by one - if err = subset.SetSubsetQueries(graph); err != nil { - return nil, fmt.Errorf("cannot set subset queries: %w", err) - } - debugQueries(tables) - } else { - // if there are no subset Tables, we can sort them by size and transformation costs - // TODO: Implement Tables ordering for subsetted Tables as well - scoreTablesEntriesAndSort(tables) - } + // Validate, build entries config and initialize transformers, set subset conditions to all Tables if provided buildWarns, err := validateAndBuildEntriesConfig( ctx, tx, tables, typeMap, cfg, r, version, types, graph, ) @@ -121,6 +111,20 @@ func NewRuntimeContext( }, nil } + // Set subset queries for Tables if they have subset conditions or sort Tables by size and transformation costs + if hasSubset(tables) { + // If table has subset the restoration must be in the topological order + // The Tables must be dumped one by one + if err = subset.SetSubsetQueries(graph); err != nil { + return nil, fmt.Errorf("cannot set subset queries: %w", err) + } + debugQueries(tables) + } else { + // if there are no subset Tables, we can sort them by size and transformation costs + // TODO: Implement Tables ordering for subsetted Tables as well + scoreTablesEntriesAndSort(tables) + } + var dataSectionObjects []entries.Entry for _, seq := range sequences { dataSectionObjects = append(dataSectionObjects, seq) diff --git a/internal/db/postgres/context/context_test.go b/internal/db/postgres/context/context_test.go index 5240b3f0..74e2791f 100644 --- a/internal/db/postgres/context/context_test.go +++ b/internal/db/postgres/context/context_test.go @@ -203,3 +203,50 @@ func TestNewRuntimeContext_regression_244(t *testing.T) { } } } + +func TestNewRuntimeContext_regression_247(t *testing.T) { + // This test is a regression test for https://github.com/GreenmaskIO/greenmask/issues/247 + // It validates that subset conditions are correctly applied to the query + ctx := context.Background() + // Start the PostgreSQL container + connStr, cleanup, err := runPostgresContainer(ctx) + require.NoError(t, err) + defer cleanup() // Ensure the container is terminated after the test + + con, err := pgx.Connect(ctx, connStr) + require.NoError(t, err) + defer con.Close(ctx) // nolint: errcheck + require.NoError(t, initTables(ctx, con, contextTestDb)) + tx, err := con.Begin(ctx) + require.NoError(t, err) + defer tx.Rollback(ctx) // nolint: errcheck + cfg := &domains.Dump{ + Transformation: []*domains.Table{ + { + Schema: "public", + Name: "users", + SubsetConds: []string{ + "public.users.user_id = '62c8c546-2420-4ca6-9961-d2cce26f7cb2'", + }, + }, + }, + } + rc, err := NewRuntimeContext(ctx, tx, cfg, utils.DefaultTransformerRegistry, nil, testContainerPgVersion*10000) + require.NoError(t, err) + require.NotNil(t, rc) + require.False(t, rc.IsFatal()) + + expectedTablesWithSubsetQuery := map[string]string{ + "users": "SELECT \"public\".\"users\".* FROM \"public\".\"users\" WHERE ( ( public.users.user_id = '62c8c546-2420-4ca6-9961-d2cce26f7cb2' ) )", + "orders": "SELECT \"public\".\"orders\".* FROM \"public\".\"orders\" LEFT JOIN \"public\".\"users\" ON \"public\".\"orders\".\"user_id\" = \"public\".\"users\".\"user_id\" AND ( public.users.user_id = '62c8c546-2420-4ca6-9961-d2cce26f7cb2' ) WHERE ( ((\"public\".\"orders\".\"user_id\" IS NULL OR \"public\".\"users\".\"user_id\" IS NOT NULL)) )", + "foo": "", + } + + for _, table := range rc.DataSectionObjects { + tab, ok := table.(*entries.Table) + if !ok { + continue + } + assert.Equalf(t, expectedTablesWithSubsetQuery[tab.Name], tab.Query, "Table %s", tab.Name) + } +} diff --git a/mkdocs.yml b/mkdocs.yml index ad44fa9b..d108ffd6 100644 --- a/mkdocs.yml +++ b/mkdocs.yml @@ -126,6 +126,7 @@ nav: - Faker function: built_in_transformers/advanced_transformers/custom_functions/faker_function.md - About: index.md - Release notes: + - Greenmask 0.2.5: release_notes/greenmask_0_2_5.md - Greenmask 0.2.4: release_notes/greenmask_0_2_4.md - Greenmask 0.2.3: release_notes/greenmask_0_2_3.md - Greenmask 0.2.2: release_notes/greenmask_0_2_2.md