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