Skip to content
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

feat: [#374] The postgres driver supports set schema #772

Merged
merged 5 commits into from
Dec 19, 2024
Merged

Conversation

hwbrzzl
Copy link
Contributor

@hwbrzzl hwbrzzl commented Dec 18, 2024

📑 Description

Closes goravel/goravel#374

Tested locally, will implement sqlserver schema in next PR.

iShot_2024-12-18_17 48 32

Summary by CodeRabbit

  • New Features

    • Added support for a new Schema field in PostgreSQL database configurations.
    • Enhanced connection string for PostgreSQL to include the search_path parameter.
    • Introduced new test cases to validate schema-related functionality.
  • Bug Fixes

    • Improved handling of default schema values in PostgreSQL configurations.
  • Tests

    • Expanded test coverage for schema management and PostgreSQL configurations.
    • Updated existing tests to utilize new schema handling methods and improved error handling.
  • Chores

    • Refactored test utilities for better schema handling and error reporting.

✅ Checks

  • Added test cases for my code

@hwbrzzl hwbrzzl requested a review from a team as a code owner December 18, 2024 09:53
Copy link
Contributor

coderabbitai bot commented Dec 18, 2024

Walkthrough

The pull request introduces support for setting a custom schema in PostgreSQL database configurations. A new Schema field is added to the Config struct, allowing developers to specify a custom schema when connecting to a PostgreSQL database. The changes span multiple files, including configuration, database connection, DSN generation, and testing utilities. The implementation ensures that when no schema is explicitly provided, it defaults to "public", maintaining backward compatibility with existing configurations.

Changes

File Change Summary
contracts/database/config.go Added Schema string field to Config struct
database/db/config_builder.go Modified fillDefault method to handle PostgreSQL schema configuration
database/db/dsn.go Updated DSN generation to include search_path parameter for PostgreSQL
database/db/dsn_test.go Added test schema constant and updated test configurations
database/gorm/query_test.go Added TestSchema function to test schema-specific queries
database/gorm/test_utils.go Enhanced test utilities to support schema configurations
database/migration/default_migrator_test.go Added schema-specific migration test
database/schema/schema.go Modified schema configuration retrieval for PostgreSQL
database/schema/schema_test.go Added TestSpecificSchema function and updated test methods
database/schema/blueprint.go Removed comment regarding future PostgreSQL schema support
database/schema/blueprint_test.go Enhanced ToSql method to handle comments for string columns

Assessment against linked issues

Objective Addressed Explanation
Add configuration for Postgres schema
Support schema in migration feature

Possibly related PRs


Thank you for using CodeRabbit. We offer it for free to the OSS community and would appreciate your support in helping us grow. If you find it useful, would you consider giving us a shout-out on your favorite social media?

❤️ Share
🪧 Tips

Chat

There are 3 ways to chat with CodeRabbit:

  • Review comments: Directly reply to a review comment made by CodeRabbit. Example:
    • I pushed a fix in commit <commit_id>, please review it.
    • Generate unit testing code for this file.
    • Open a follow-up GitHub issue for this discussion.
  • Files and specific lines of code (under the "Files changed" tab): Tag @coderabbitai in a new review comment at the desired location with your query. Examples:
    • @coderabbitai generate unit testing code for this file.
    • @coderabbitai modularize this function.
  • PR comments: Tag @coderabbitai in a new PR comment to ask questions about the PR branch. For the best results, please provide a very specific query, as very limited context is provided in this mode. Examples:
    • @coderabbitai gather interesting stats about this repository and render them as a table. Additionally, render a pie chart showing the language distribution in the codebase.
    • @coderabbitai read src/utils.ts and generate unit testing code.
    • @coderabbitai read the files in the src/scheduler package and generate a class diagram using mermaid and a README in the markdown format.
    • @coderabbitai help me debug CodeRabbit configuration file.

Note: Be mindful of the bot's finite context window. It's strongly recommended to break down tasks such as reading entire modules into smaller chunks. For a focused discussion, use review comments to chat about specific files and their changes, instead of using the PR comments.

CodeRabbit Commands (Invoked using PR comments)

  • @coderabbitai pause to pause the reviews on a PR.
  • @coderabbitai resume to resume the paused reviews.
  • @coderabbitai review to trigger an incremental review. This is useful when automatic reviews are disabled for the repository.
  • @coderabbitai full review to do a full review from scratch and review all the files again.
  • @coderabbitai summary to regenerate the summary of the PR.
  • @coderabbitai resolve resolve all the CodeRabbit review comments.
  • @coderabbitai configuration to show the current CodeRabbit configuration for the repository.
  • @coderabbitai help to get help.

Other keywords and placeholders

  • Add @coderabbitai ignore anywhere in the PR description to prevent this PR from being reviewed.
  • Add @coderabbitai summary to generate the high-level summary at a specific location in the PR description.
  • Add @coderabbitai anywhere in the PR title to generate the title automatically.

CodeRabbit Configuration File (.coderabbit.yaml)

  • You can programmatically configure CodeRabbit by adding a .coderabbit.yaml file to the root of your repository.
  • Please see the configuration documentation for more information.
  • If your editor has YAML language server enabled, you can add the path at the top of this file to enable auto-completion and validation: # yaml-language-server: $schema=https://coderabbit.ai/integrations/schema.v2.json

Documentation and Community

  • Visit our Documentation for detailed information on how to use CodeRabbit.
  • Join our Discord Community to get help, request features, and share feedback.
  • Follow us on X/Twitter for updates and announcements.

Copy link

codecov bot commented Dec 18, 2024

Codecov Report

Attention: Patch coverage is 72.85714% with 19 lines in your changes missing coverage. Please review.

Project coverage is 69.94%. Comparing base (b982188) to head (9e1f4c4).
Report is 1 commits behind head on master.

Files with missing lines Patch % Lines
database/gorm/test_utils.go 75.00% 11 Missing and 5 partials ⚠️
database/db/config_builder.go 0.00% 2 Missing and 1 partial ⚠️
Additional details and impacted files
@@            Coverage Diff             @@
##           master     #772      +/-   ##
==========================================
- Coverage   69.97%   69.94%   -0.04%     
==========================================
  Files         213      213              
  Lines       18119    18164      +45     
==========================================
+ Hits        12679    12705      +26     
- Misses       4749     4762      +13     
- Partials      691      697       +6     

☔ View full report in Codecov by Sentry.
📢 Have feedback on the report? Share it here.

Copy link
Contributor

@coderabbitai coderabbitai bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Actionable comments posted: 1

🧹 Nitpick comments (5)
database/gorm/test_utils.go (1)

169-187: Robust error handling and resource creation.

The NewTestQuery function effectively constructs a test query, handles errors, and sets up relevant mocks. Consider adding clearer logs or additional checks for partial initialization failures.

contracts/database/config.go (1)

24-25: Introducing Schema field for Postgres.

Adding this field extends configuration flexibility. Please ensure external references, environment variables, and docs mention the new field for clarity.

database/db/dsn_test.go (1)

18-18: Add more test cases for schema handling.

While the basic test case is good, consider adding test cases for:

  1. Custom schema names
  2. Empty schema handling
  3. Invalid schema names (once validation is added)

Add these test cases:

 func TestDsn(t *testing.T) {
 	tests := []struct {
 		name      string
 		config    database.FullConfig
 		expectDsn string
 	}{
+		{
+			name: "postgres with custom schema",
+			config: database.FullConfig{
+				Config: database.Config{
+					Host: testHost,
+					Port: testPort,
+					Database: testDatabase,
+					Username: testUsername,
+					Password: testPassword,
+					Schema: "custom_schema",
+				},
+				Driver: database.DriverPostgres,
+				Sslmode: "disable",
+				Timezone: "UTC",
+			},
+			expectDsn: fmt.Sprintf("postgres://%s:%s@%s:%d/%s?sslmode=%s&timezone=%s&search_path=%s",
+				testUsername, testPassword, testHost, testPort, testDatabase, "disable", "UTC", "custom_schema"),
+		},
+		{
+			name: "postgres with empty schema",
+			config: database.FullConfig{
+				Config: database.Config{
+					Host: testHost,
+					Port: testPort,
+					Database: testDatabase,
+					Username: testUsername,
+					Password: testPassword,
+					Schema: "",
+				},
+				Driver: database.DriverPostgres,
+				Sslmode: "disable",
+				Timezone: "UTC",
+			},
+			expectDsn: fmt.Sprintf("postgres://%s:%s@%s:%d/%s?sslmode=%s&timezone=%s&search_path=%s",
+				testUsername, testPassword, testHost, testPort, testDatabase, "disable", "UTC", "public"),
+		},

Also applies to: 27-27, 70-71

database/schema/schema.go (1)

47-47: LGTM! Consider adding documentation

The implementation correctly handles PostgreSQL schema configuration with a proper default value of "public".

Consider adding a code comment explaining the significance of the "public" schema in PostgreSQL and when users might want to configure a different schema.

foundation/application_test.go (1)

Line range hint 47-47: Consider documenting schema usage patterns

The implementation of PostgreSQL schema support is solid. Consider adding documentation in the README or configuration guide about:

  1. When and why users might want to use different schemas
  2. Best practices for schema management
  3. Migration considerations when using custom schemas
📜 Review details

Configuration used: CodeRabbit UI
Review profile: CHILL
Plan: Pro

📥 Commits

Reviewing files that changed from the base of the PR and between 1a81ebb and ee8c73a.

📒 Files selected for processing (12)
  • contracts/database/config.go (1 hunks)
  • database/db/config_builder.go (1 hunks)
  • database/db/dsn.go (1 hunks)
  • database/db/dsn_test.go (3 hunks)
  • database/gorm/query_test.go (1 hunks)
  • database/gorm/test_utils.go (8 hunks)
  • database/migration/default_migrator_test.go (3 hunks)
  • database/migration/repository_test.go (1 hunks)
  • database/schema/common_schema_test.go (1 hunks)
  • database/schema/schema.go (1 hunks)
  • database/schema/schema_test.go (4 hunks)
  • foundation/application_test.go (1 hunks)
🔇 Additional comments (23)
database/gorm/test_utils.go (10)

38-38: New interface method for schema support.

The introduction of WithSchema(schema string) expands the interface for driver mocks, improving test coverage of schema-specific features.


149-155: Clear separation of prefix-and-singular code paths.

This conditional logic neatly segregates creation of queries with or without prefix-and-singular, promoting maintainability. No major issues found.


189-207: Method dedicated to prefix-and-singular initialization.

Adding NewTestQueryWithPrefixAndSingular clarifies test setup. The approach is consistent with the rest of the codebase.


344-346: MySQL schema support not implemented.

This function panics intentionally since MySQL doesn’t support user-defined schemas in the same way. Properly documented.


395-395: Default schema handling for Postgres.

Retrieving and defaulting to "public" is consistent, ensuring backward-compatibility for unspecified schemas.


410-410: Ensuring read/write handles default schema.

Again, the fallback to "public" is appropriate. No issues.


417-420: Prefix, singular, and schema usage.

Using WithPrefixAndSingular in tandem with a default schema maintains test uniformity.


422-425: Dynamic schema configuration in Postgres mock.

This newly added method properly sets up the schema override, verifying the "schema" key in the mock config.


493-495: SQLite schema usage panic.

SQLite doesn’t support distinct schemas. This panic clarifies unsupported usage.


559-561: SQL Server schema not supported yet.

Indicates a known limitation in the driver. Future expansions can remove this panic once schema support is ready.

database/schema/schema_test.go (4)

8-9: Additional testing libraries asserted.

The introduction of assert and require ensures more intuitive unit testing.


38-38: Migration to NewTestQueryWithPrefixAndSingular.

Replacing direct calls in SetupTest clarifies the test approach for prefix and singular.

Also applies to: 41-41, 46-46, 51-51


2334-2354: TestSpecificSchema ensures custom schema creation.

This thorough test confirms that tables can be created in a user-defined schema. Properly checks table name, schema name, and handles Docker readiness.


2154-2154: Mock configuration usage in teardown.

Checking for empty schema with a mock ensures graceful cleanup. This line highlights asynchronous interactions that might require caution if parallel tests are introduced.

✅ Verification successful

Let me gather more context about the test setup and teardown patterns.


Based on the context gathered, I can now generate the final response:

Mock configuration usage is appropriate and safe in this context

The mock configuration is used in a controlled test teardown sequence for dropping tables, and there's no evidence of parallel test execution in the codebase. The .Once() expectation ensures proper cleanup of the mock after use.

🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Search for references to testQuery.MockConfig() in teardown to ensure consistent usage
rg "testQuery.MockConfig()" -A 5

Length of output: 1263


Script:

#!/bin/bash
# Look for the test context around the MockConfig usage
rg -B 10 -A 10 "testQuery\.MockConfig\(\)\.EXPECT\(\)\.GetString\(\"database\.connections\.postgres\.schema\"\)"

# Also check for parallel test configurations
ast-grep --pattern 'func ($name *testing.T) {
  $$$
  $name.Parallel()
  $$$
}'

Length of output: 1428

database/schema/common_schema_test.go (1)

31-31: Prefixed test query for Postgres.

This change aligns common_schema_test with the updated function usage. The test suite remains consistent across all DB drivers.

database/db/config_builder.go (1)

76-78: LGTM! Default schema handling looks correct.

The implementation properly handles the schema configuration for PostgreSQL with a sensible default of "public". This follows PostgreSQL conventions and maintains backward compatibility.

Let's verify the schema configuration handling:

✅ Verification successful

Let me gather more information about the schema handling implementation.


Schema configuration handling is consistent across the codebase

The verification confirms that the schema configuration with default "public" is consistently implemented:

  • The config_builder correctly handles schema configuration for PostgreSQL
  • Test utilities properly mock the schema configuration with the same default
  • Schema package uses the same configuration pattern and default value
  • All schema-related configurations follow the same path format: "database.connections.{connection}.schema"
🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Check if schema configuration is consistently handled across the codebase
rg -g '*.go' -A 2 -B 2 'schema.*postgres|postgres.*schema'

Length of output: 2580


Script:

#!/bin/bash
# Check schema-related code in config_builder and related files
ast-grep --pattern 'Schema.*=.*public'

# Check for any other schema-related configuration handling
rg -g '*.go' 'GetString.*schema' -A 2 -B 2

Length of output: 3712

database/db/dsn.go (1)

23-24: 🛠️ Refactor suggestion

Consider adding schema name validation.

While the implementation correctly adds the schema to the search_path, we should ensure the schema name is properly validated to prevent potential SQL injection. PostgreSQL schema names could contain special characters that might need escaping.

Let's check for any existing schema name validation:

Consider adding schema name validation:

 func Dsn(config database.FullConfig) string {
+	// Validate schema name to prevent SQL injection
+	if !isValidSchemaName(config.Schema) {
+		return ""
+	}
 	if config.Dsn != "" {
 		return config.Dsn
 	}
database/migration/repository_test.go (1)

32-32: Verify test coverage with schema configurations

The change to use NewTestQueryWithPrefixAndSingular looks good, but let's ensure it properly handles schema configurations in tests.

✅ Verification successful

Let's examine the test coverage more deeply by looking at the actual test cases.


Let's check the implementation of NewTestQueryWithPrefixAndSingular to understand how it relates to schema handling.


Let's check one more thing to understand the relationship between schema handling and the test setup.


Let's check one final thing - the implementation of NewTestQueryWithPrefixAndSingular to understand how it handles schema configuration.


Based on the comprehensive analysis of the codebase, I can now generate the final response:

Schema handling is properly covered in test configurations

The change to NewTestQueryWithPrefixAndSingular is well-supported by the test infrastructure:

  • The test suite includes dedicated schema test cases in database/schema/schema_test.go
  • The repository tests properly initialize test queries with schema support through schema.GetTestSchema
  • Schema configurations are properly handled in both PostgreSQL and SQLServer drivers
🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Description: Verify test coverage for schema configurations
# Check if there are corresponding test cases for schema handling

# Search for schema-related test cases
rg -l "schema.*test" database/

Length of output: 205


Script:

#!/bin/bash
# Check the actual test cases in repository_test.go and related files
rg "func.*Test.*Schema" database/ -A 5

# Also check for schema-related assertions in repository_test.go
rg "schema" database/migration/repository_test.go

Length of output: 4506


Script:

#!/bin/bash
# Check the implementation of NewTestQueryWithPrefixAndSingular
ast-grep --pattern 'func NewTestQueryWithPrefixAndSingular' -A 20

# Also check how it's used in repository_test.go
rg -B 2 -A 5 "NewTestQueryWithPrefixAndSingular" database/migration/repository_test.go

Length of output: 381


Script:

#!/bin/bash
# Check the test file content to understand the test setup and assertions
cat database/migration/repository_test.go

# Also check if there are any other tests using NewTestQueryWithPrefixAndSingular
rg "NewTestQueryWithPrefixAndSingular" database/

Length of output: 4917


Script:

#!/bin/bash
# Check the implementation of NewTestQueryWithPrefixAndSingular in test_utils.go
cat database/gorm/test_utils.go

Length of output: 38051

foundation/application_test.go (1)

334-334: LGTM! Test coverage looks good

The test properly verifies the schema configuration behavior with the default value.

database/migration/default_migrator_test.go (3)

12-12: LGTM: Good practice using require package

Using require package for assertions is a good practice as it provides better error messages and stops test execution on failure.


47-70: LGTM: Improved test setup with better error handling

The test setup has been enhanced with:

  • Proper error handling using Require().NoError
  • Clear separation of test query setup for different databases
  • Consistent initialization pattern

120-136: LGTM: Well-structured schema support test

The test case properly validates schema support by:

  1. Setting up a Postgres docker instance
  2. Creating a test query with "goravel" schema
  3. Testing basic CRUD operations within the schema
  4. Using appropriate assertions
database/gorm/query_test.go (1)

3834-3848: LGTM: Comprehensive schema support test

The test case effectively validates schema support by:

  1. Setting up a Postgres docker instance
  2. Creating a test query with "goravel" schema
  3. Testing basic CRUD operations
  4. Using appropriate assertions

The test structure aligns well with the existing test patterns in the file.

database/gorm/test_utils.go Show resolved Hide resolved
coderabbitai[bot]
coderabbitai bot previously approved these changes Dec 18, 2024
coderabbitai[bot]
coderabbitai bot previously approved these changes Dec 18, 2024
Copy link

@github-actions github-actions bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

⚠️ Performance Alert ⚠️

Possible performance regression was detected for benchmark.
Benchmark result of this commit is worse than the previous benchmark result exceeding threshold 1.50.

Benchmark suite Current: 55f892c Previous: 1a81ebb Ratio
BenchmarkFile_ReadWrite 320408 ns/op 2072 B/op 27 allocs/op 188050 ns/op 2072 B/op 27 allocs/op 1.70
BenchmarkFile_ReadWrite - ns/op 320408 ns/op 188050 ns/op 1.70

This comment was automatically generated by workflow using github-action-benchmark.

@devhaozi
Copy link
Member

@coderabbitai full review

Copy link
Contributor

coderabbitai bot commented Dec 19, 2024

✅ Actions performed

Full review triggered.

Copy link
Contributor

@coderabbitai coderabbitai bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Actionable comments posted: 1

🧹 Nitpick comments (1)
database/gorm/query_test.go (1)

3834-3852: Test implementation looks good but could be more comprehensive.

The basic test implementation for schema support is correct, but consider enhancing it with:

  1. Additional test cases:

    • Verify operations fail with incorrect schema
    • Test schema switching
    • Validate data isolation between schemas
  2. Schema verification:

    • Add assertions to confirm data is stored in the correct schema
    • Test schema-specific queries

Consider expanding the test with these additional cases:

 func TestSchema(t *testing.T) {
     if env.IsWindows() {
         t.Skip("Skip test that using Docker")
     }

     postgresDocker := supportdocker.Postgres()
     require.NoError(t, postgresDocker.Ready())

     testQuery := NewTestQueryWithSchema(postgresDocker, "goravel")
     testQuery.CreateTable(TestTableUsers)

     user := User{Name: "first_user"}
     assert.Nil(t, testQuery.Query().Create(&user))
     assert.True(t, user.ID > 0)

     var user1 User
     assert.Nil(t, testQuery.Query().Where("name", "first_user").First(&user1))
     assert.True(t, user1.ID > 0)
+
+    // Test schema isolation
+    defaultQuery := NewTestQuery(postgresDocker)
+    defaultQuery.CreateTable(TestTableUsers)
+    
+    var user2 User
+    assert.Nil(t, defaultQuery.Query().Where("name", "first_user").First(&user2))
+    assert.Equal(t, uint(0), user2.ID, "User should not be found in default schema")
+
+    // Verify schema switching
+    testQuery2 := NewTestQueryWithSchema(postgresDocker, "another_schema")
+    testQuery2.CreateTable(TestTableUsers)
+    
+    user3 := User{Name: "second_user"}
+    assert.Nil(t, testQuery2.Query().Create(&user3))
+    assert.True(t, user3.ID > 0)
+
+    var user4 User
+    assert.Nil(t, testQuery.Query().Where("name", "second_user").First(&user4))
+    assert.Equal(t, uint(0), user4.ID, "User should not be found in different schema")
+
+    // Cleanup
+    require.NoError(t, postgresDocker.Shutdown())
 }
📜 Review details

Configuration used: CodeRabbit UI
Review profile: CHILL
Plan: Pro

📥 Commits

Reviewing files that changed from the base of the PR and between bf91f1f and 9e1f4c4.

📒 Files selected for processing (4)
  • database/gorm/query_test.go (1 hunks)
  • database/migration/default_migrator_test.go (4 hunks)
  • database/schema/blueprint_test.go (1 hunks)
  • database/schema/schema_test.go (4 hunks)
🔇 Additional comments (6)
database/schema/blueprint_test.go (1)

373-376: LGTM: Test case properly handles PostgreSQL column comments

The test case correctly verifies that PostgreSQL generates two SQL statements when creating a table with column comments - one for table creation and another for setting the column comment.

database/migration/default_migrator_test.go (2)

47-70: LGTM: Improved test setup with better error handling

The changes improve the test setup by:

  1. Using Require().NoError for critical setup steps which fails fast on errors
  2. Properly initializing test queries for all supported database drivers

154-174: LGTM: Comprehensive test coverage for schema support

The new test function properly verifies PostgreSQL schema support by:

  1. Creating a custom schema
  2. Creating a table within that schema
  3. Verifying the operation's success
database/schema/schema_test.go (3)

8-9: LGTM: Added necessary test utility imports

Added required testify imports for improved test assertions.


2154-2154: LGTM: Added schema configuration test coverage

Added mock expectation to verify behavior when no schema is configured (default case).


2334-2358: LGTM: Added comprehensive schema-specific test

The new test function provides thorough verification of schema support:

  1. Creates a table in a specific schema
  2. Verifies table creation
  3. Validates schema name in table metadata

database/gorm/query_test.go Show resolved Hide resolved
Copy link
Contributor

@coderabbitai coderabbitai bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Actionable comments posted: 2

♻️ Duplicate comments (1)
database/gorm/query_test.go (1)

3839-3841: ⚠️ Potential issue

Add container cleanup to prevent resource leaks.

The PostgreSQL Docker container is not being cleaned up after the test, which could lead to resource leaks.

Add container cleanup in a defer statement right after container creation:

 postgresDocker := supportdocker.Postgres()
 require.NoError(t, postgresDocker.Ready())
+defer func() {
+    require.NoError(t, postgresDocker.Shutdown())
+}()
🧹 Nitpick comments (6)
database/migration/default_migrator_test.go (1)

72-74: Teardown step for SQLite
Calling s.driverToTestQuery[contractsdatabase.DriverSqlite].Docker().Shutdown() is good housekeeping to prevent leftover resources. For other drivers, consider applying a similar teardown routine whenever feasible, to ensure containers aren’t left running.

database/gorm/test_utils.go (2)

189-207: Isolated logic for prefix + singular testing
NewTestQueryWithPrefixAndSingular clearly serves specialized test conditions. Ensuring each constructor has a single responsibility leads to a more flexible test setup.

🧰 Tools
🪛 GitHub Check: codecov/patch

[warning] 201-201: database/gorm/test_utils.go#L201
Added line #L201 was not covered by tests


559-560: SQL Server partial schema support
The panic message clarifies “sqlserver does not support schema for now.” If partial or future support is planned, consider referencing an issue or placeholder for future extension.

🧰 Tools
🪛 GitHub Check: codecov/patch

[warning] 559-560: database/gorm/test_utils.go#L559-L560
Added lines #L559 - L560 were not covered by tests

database/db/dsn_test.go (1)

18-18: Add test cases for different schema scenarios

While the basic schema test is good, consider adding test cases for:

  1. Empty schema (should default to "public")
  2. Custom schema values
  3. Invalid schema names (after implementing validation)

Example test cases to add:

{
    name: "postgres with empty schema",
    config: database.FullConfig{
        Config: database.Config{
            // ... other fields ...
            Schema: "", // Empty schema
        },
        Driver: database.DriverPostgres,
        // ... other fields ...
    },
    expectDsn: "postgres://...&search_path=public", // Should use default
},
{
    name: "postgres with custom schema",
    config: database.FullConfig{
        Config: database.Config{
            // ... other fields ...
            Schema: "custom_schema",
        },
        Driver: database.DriverPostgres,
        // ... other fields ...
    },
    expectDsn: "postgres://...&search_path=custom_schema",
},

Also applies to: 27-27, 70-71

database/schema/schema.go (1)

47-47: LGTM! Consider adding documentation

The implementation correctly handles schema configuration with a sensible default of "public". This is a good practice for PostgreSQL databases.

Consider adding a comment explaining the schema configuration option in the code, for example:

+// Default schema is "public" for PostgreSQL if not explicitly configured
schema = config.GetString(fmt.Sprintf("database.connections.%s.schema", orm.Name()), "public")
database/schema/blueprint_test.go (1)

373-376: LGTM! Consider additional test cases

The test correctly verifies PostgreSQL-specific behavior for column comments. The implementation is clean and well-structured.

Consider adding test cases for:

  1. Multiple column comments in a single table
  2. Comments with special characters
  3. Schema-specific column comments

Example addition:

+// Test multiple column comments
+s.blueprint.Create()
+s.blueprint.String("name").Comment("name comment")
+s.blueprint.String("description").Comment("desc comment")
+if driver == database.DriverPostgres {
+    s.Len(s.blueprint.ToSql(grammar), 3)
+}
📜 Review details

Configuration used: CodeRabbit UI
Review profile: CHILL
Plan: Pro

📥 Commits

Reviewing files that changed from the base of the PR and between b982188 and 9e1f4c4.

📒 Files selected for processing (14)
  • contracts/database/config.go (1 hunks)
  • database/db/config_builder.go (1 hunks)
  • database/db/dsn.go (1 hunks)
  • database/db/dsn_test.go (3 hunks)
  • database/gorm/query_test.go (1 hunks)
  • database/gorm/test_utils.go (8 hunks)
  • database/migration/default_migrator_test.go (4 hunks)
  • database/migration/repository_test.go (1 hunks)
  • database/schema/blueprint.go (0 hunks)
  • database/schema/blueprint_test.go (1 hunks)
  • database/schema/common_schema_test.go (1 hunks)
  • database/schema/schema.go (1 hunks)
  • database/schema/schema_test.go (4 hunks)
  • foundation/application_test.go (1 hunks)
💤 Files with no reviewable changes (1)
  • database/schema/blueprint.go
🧰 Additional context used
🪛 GitHub Check: codecov/patch
database/db/config_builder.go

[warning] 77-78: database/db/config_builder.go#L77-L78
Added lines #L77 - L78 were not covered by tests

database/gorm/test_utils.go

[warning] 181-181: database/gorm/test_utils.go#L181
Added line #L181 was not covered by tests


[warning] 201-201: database/gorm/test_utils.go#L201
Added line #L201 was not covered by tests


[warning] 211-211: database/gorm/test_utils.go#L211
Added line #L211 was not covered by tests


[warning] 220-220: database/gorm/test_utils.go#L220
Added line #L220 was not covered by tests


[warning] 224-224: database/gorm/test_utils.go#L224
Added line #L224 was not covered by tests


[warning] 344-345: database/gorm/test_utils.go#L344-L345
Added lines #L344 - L345 were not covered by tests


[warning] 493-494: database/gorm/test_utils.go#L493-L494
Added lines #L493 - L494 were not covered by tests


[warning] 559-560: database/gorm/test_utils.go#L559-L560
Added lines #L559 - L560 were not covered by tests

🔇 Additional comments (21)
database/migration/default_migrator_test.go (6)

12-12: Use of "require" for immediate test failure is good practice
Switching from s.NoError to s.Require().NoError ensures that test execution stops immediately if this step fails, preventing subsequent assertions from running on invalid states.


47-48: Immediate readiness check ensures test stability
Calling s.Require().NoError(postgresDocker.Ready()) here helps confirm that the Docker container is fully ready before proceeding. This avoids hard-to-trace errors from partially initialized containers.


49-50: Consistent creation of Postgres test query
Creating a new test query object with prefix and singular settings is consistent with the updated approach. This helps ensure naming consistency across migrations and queries.


65-70: Streamlined driver assignment
Organizing the driver to test query mappings here makes the test suite easier to maintain and read. The approach is concise and follows a uniform pattern for each driver.


91-92: Explicit status check after migrations
Confirming the migration status helps validate that the migrations have actually run as expected.


154-175: Integration test for schema-specific migrations
Introducing TestDefaultMigratorWithWithSchema ensures that the new schema handling logic is correctly validated. This helps confirm that migrations target the intended schema rather than defaulting to "public".

database/gorm/test_utils.go (5)

149-155: Refactored query creation with prefix and singular
Using a separate function (NewTestQueryWithPrefixAndSingular) clarifies intent and avoids overloading the standard NewTestQuery. This separation helps maintain a clear interface for different testing scenarios.


169-187: Enhanced clarity for basic test query creation
NewTestQuery now reads more succinctly, focusing on minimal setup while delegating prefix/singular logic to other constructors. This design is clean and improves maintainability.

🧰 Tools
🪛 GitHub Check: codecov/patch

[warning] 181-181: database/gorm/test_utils.go#L181
Added line #L181 was not covered by tests


209-237: Schema creation for testing without teardown
You create a custom schema (“CREATE SCHEMA %s”) for tests but don’t drop it afterward. Over time or in concurrent runs, this can create clutter and potential resource constraints. Consider adding a cleanup step in test teardown.

Here’s an example approach:

  1. Add a mechanism to track schemas created in NewTestQueryWithSchema.
  2. Provide a teardown or cleanup method to drop these schemas at the end of the tests.
🧰 Tools
🪛 GitHub Check: codecov/patch

[warning] 211-211: database/gorm/test_utils.go#L211
Added line #L211 was not covered by tests


[warning] 220-220: database/gorm/test_utils.go#L220
Added line #L220 was not covered by tests


[warning] 224-224: database/gorm/test_utils.go#L224
Added line #L224 was not covered by tests


344-345: Confirmed MySQL schema usage raises an error
The panic is appropriate since MySQL doesn’t support separately named schemas. This makes the limitation explicit.

🧰 Tools
🪛 GitHub Check: codecov/patch

[warning] 344-345: database/gorm/test_utils.go#L344-L345
Added lines #L344 - L345 were not covered by tests


493-494: SQLite schema usage raises an error
Similarly for SQLite, the panic clarifies that custom schemas are not supported, making behavior predictable.

🧰 Tools
🪛 GitHub Check: codecov/patch

[warning] 493-494: database/gorm/test_utils.go#L493-L494
Added lines #L493 - L494 were not covered by tests

contracts/database/config.go (1)

24-25: Schema field addition
Adding Schema string broadens configuration for PostgreSQL while preserving backward compatibility for other drivers.

database/schema/common_schema_test.go (1)

31-31: Use of NewTestQueryWithPrefixAndSingular
Switching to the dedicated constructor clarifies that prefix and singular naming conventions are in effect for this test. This improves consistency with the rest of the codebase.

database/db/dsn.go (1)

23-24: LGTM! PostgreSQL DSN format is correct

The addition of search_path parameter to the PostgreSQL connection string is implemented correctly.

foundation/application_test.go (1)

334-334: LGTM! Test coverage added for postgres schema configuration.

The test properly verifies the new schema configuration functionality by expecting the schema config to be retrieved with a default value of "public".

database/schema/schema_test.go (4)

8-9: LGTM! Enhanced test assertions with better testing packages.

The addition of assert/require packages improves test assertions and error handling.


38-38: LGTM! Standardized test query initialization.

Test query initialization updated to use WithPrefixAndSingular consistently across test files.

Also applies to: 41-41, 46-46, 51-51


2154-2154: LGTM! Updated schema configuration path.

Schema configuration retrieval updated to use the new standardized path.


2334-2358: LGTM! Comprehensive test coverage for schema-specific functionality.

The new test validates:

  • Table creation in a specific schema
  • Schema name verification
  • Table existence checks

Run the following script to verify schema-related test coverage:

✅ Verification successful

Schema-specific functionality is well-tested across the codebase

The verification shows comprehensive test coverage for schema functionality:

  • Schema-specific operations in TestSpecificSchema
  • Schema handling across different database drivers (Postgres, MySQL, SQLite, SQLServer)
  • Schema operations including:
    • Table creation and verification
    • Column operations
    • Index management
    • Foreign key relationships
    • Enum types
    • Views
    • Custom SQL execution
🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Description: Verify test coverage for schema functionality
# Test: Search for schema-related tests. Expect: Tests for creation, verification and table operations.
rg -A 5 'TestSpecific.*Schema|schema.*test'

Length of output: 14523

database/gorm/query_test.go (1)

3834-3852: LGTM! Added test coverage for schema-specific queries.

The test validates:

  • Table creation in a specific schema
  • Record creation and retrieval
database/migration/repository_test.go (1)

32-32: Verify test coverage with schema configurations

The change to use NewTestQueryWithPrefixAndSingular aligns with schema support. However, we should ensure test coverage for various schema configurations.

✅ Verification successful

Let me gather more information about the new method and its usage.


Let me check one more thing to understand the implementation of NewTestQueryWithPrefixAndSingular and its relationship with NewTestQuery.


Schema-related test coverage is comprehensive

The change to use NewTestQueryWithPrefixAndSingular is well-aligned with existing test coverage. The method is already being used across multiple test files including schema_test.go, common_schema_test.go, and default_migrator_test.go, covering all supported database drivers (Postgres, SQLite, MySQL, and SQL Server). The change in repository_test.go follows this established pattern.

🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Description: Check test coverage for schema-related functionality
# Look for other test files that might need similar updates

# Find all test files that might need similar updates
fd -e go -t f "test" | xargs rg "NewTestQuery\("

Length of output: 1232


Script:

#!/bin/bash
# Check the implementation and usage of NewTestQueryWithPrefixAndSingular
ast-grep --pattern 'func NewTestQueryWithPrefixAndSingular'

# Also check for any existing tests with schema configurations
rg -l "schema|prefix|singular" database/

Length of output: 1976


Script:

#!/bin/bash
# Check the implementation of both methods and their relationship
rg -A 5 "func NewTestQuery|func NewTestQueryWithPrefixAndSingular" database/

# Also check for any existing tests using NewTestQueryWithPrefixAndSingular
rg "NewTestQueryWithPrefixAndSingular" database/

Length of output: 2771

database/db/config_builder.go Show resolved Hide resolved
@devhaozi
Copy link
Member

@coderabbitai resolve

Copy link
Contributor

coderabbitai bot commented Dec 19, 2024

✅ Actions performed

Comments resolved.

@devhaozi devhaozi enabled auto-merge (squash) December 19, 2024 11:29
Copy link
Member

@devhaozi devhaozi left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM

@devhaozi devhaozi merged commit b2d2fe8 into master Dec 19, 2024
11 checks passed
@devhaozi devhaozi deleted the bowen/#374 branch December 19, 2024 11:29
hwbrzzl added a commit that referenced this pull request Dec 20, 2024
* feat: [#374] The postgres driver supports set schema

* fix test

* remove comment

* add test cases

---------

Co-authored-by: 耗子 <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

✨ [Feature] The postgres driver supports set schema
2 participants