Skip to content

Commit

Permalink
refactor(repository): move migrations to folder and refactor repository
Browse files Browse the repository at this point in the history
  • Loading branch information
renan061 committed Aug 29, 2024
1 parent 8fa5dca commit e514801
Show file tree
Hide file tree
Showing 10 changed files with 134 additions and 176 deletions.
13 changes: 6 additions & 7 deletions cmd/cartesi-rollups-cli/root/db/check/check.go
Original file line number Diff line number Diff line change
Expand Up @@ -3,10 +3,10 @@
package check

import (
"fmt"
"log/slog"

"github.com/cartesi/rollups-node/cmd/cartesi-rollups-cli/root/common"
"github.com/cartesi/rollups-node/internal/repository"
"github.com/cartesi/rollups-node/internal/repository/schema"
"github.com/spf13/cobra"
)

Expand All @@ -17,13 +17,12 @@ var Cmd = &cobra.Command{
}

func run(cmd *cobra.Command, args []string) {

schemaManager, err := repository.NewSchemaManager(common.PostgresEndpoint)
schema, err := schema.New(common.PostgresEndpoint)
cobra.CheckErr(err)
defer schemaManager.Close()
defer schema.Close()

err = schemaManager.ValidateSchemaVersion()
version, err := schema.ValidateVersion()
cobra.CheckErr(err)

fmt.Printf("Database Schema is at the correct version: %d\n", repository.EXPECTED_VERSION)
slog.Info("Database Schema is at the correct version.", "version", version)
}
19 changes: 6 additions & 13 deletions cmd/cartesi-rollups-cli/root/db/upgrade/upgrade.go
Original file line number Diff line number Diff line change
Expand Up @@ -3,11 +3,10 @@
package upgrade

import (
"fmt"
"log/slog"

"github.com/cartesi/rollups-node/cmd/cartesi-rollups-cli/root/common"
"github.com/cartesi/rollups-node/internal/repository"
"github.com/cartesi/rollups-node/internal/repository/schema"
"github.com/spf13/cobra"
)

Expand All @@ -18,21 +17,15 @@ var Cmd = &cobra.Command{
}

func run(cmd *cobra.Command, args []string) {

schemaManager, err := repository.NewSchemaManager(common.PostgresEndpoint)
schema, err := schema.New(common.PostgresEndpoint)
cobra.CheckErr(err)
defer schemaManager.Close()
defer schema.Close()

err = schemaManager.Upgrade()
err = schema.Upgrade()
cobra.CheckErr(err)

version, err := schemaManager.GetVersion()
version, err := schema.ValidateVersion()
cobra.CheckErr(err)

if repository.EXPECTED_VERSION != version {
slog.Warn("Current version is different to expected one")
}

fmt.Printf("Database Schema successfully Updated. Current version is %d\n", version)

slog.Info("Database Schema successfully Updated.", "version", version)
}
29 changes: 9 additions & 20 deletions internal/node/startup/startup.go
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,7 @@ import (
"github.com/cartesi/rollups-node/internal/node/config"
"github.com/cartesi/rollups-node/internal/node/model"
"github.com/cartesi/rollups-node/internal/repository"
"github.com/cartesi/rollups-node/internal/repository/schema"
"github.com/ethereum/go-ethereum/common"
"github.com/jackc/pgx/v5"
"github.com/lmittmann/tint"
Expand All @@ -20,31 +21,19 @@ import (

// Validates the Node Database Schema Version
func ValidateSchema(config config.NodeConfig) error {
var (
schemaManager *repository.SchemaManager
err error
)

if !config.PostgresSslMode {
schemaManager, err = repository.NewSchemaManager(
fmt.Sprintf("%v?sslmode=disable", config.PostgresEndpoint.Value))
if err != nil {
return err
}
} else {
schemaManager, err = repository.NewSchemaManager(config.PostgresEndpoint.Value)
if err != nil {
return err
}
endpoint := config.PostgresEndpoint.Value
if config.PostgresSslMode {
endpoint += "?sslmode=disable"
}
defer schemaManager.Close()
err = schemaManager.ValidateSchemaVersion()

schema, err := schema.New(endpoint)
if err != nil {
return err
}
defer schema.Close()

return nil

_, err = schema.ValidateVersion()
return err
}

// Configure the node logs
Expand Down
28 changes: 3 additions & 25 deletions internal/repository/base_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@ import (
"time"

. "github.com/cartesi/rollups-node/internal/node/model"
"github.com/cartesi/rollups-node/internal/repository/schema"
"github.com/ethereum/go-ethereum/common"
"github.com/stretchr/testify/suite"
"github.com/testcontainers/testcontainers-go"
Expand Down Expand Up @@ -38,10 +39,10 @@ func (s *RepositorySuite) SetupSuite() {
endpoint, err := s.postgres.ConnectionString(s.ctx, "sslmode=disable")
s.Require().Nil(err)

schemaManager, err := NewSchemaManager(endpoint)
schema, err := schema.New(endpoint)
s.Require().Nil(err)

err = schemaManager.Upgrade()
err = schema.Upgrade()
s.Require().Nil(err)

s.database, err = Connect(s.ctx, endpoint)
Expand Down Expand Up @@ -334,18 +335,6 @@ func (s *RepositorySuite) TestOutputDoesntExist() {
s.Require().Nil(err)
}

func (s *RepositorySuite) TestOutputFailsDuplicateRow() {
output := Output{
Index: 1,
InputId: 1,
RawData: common.Hex2Bytes("deadbeef"),
OutputHashesSiblings: nil,
}

_, err := s.database.InsertOutput(s.ctx, &output)
s.Require().ErrorContains(err, "duplicate key value")
}

func (s *RepositorySuite) TestOutputFailsInputDoesntExist() {
output := Output{
Index: 10,
Expand Down Expand Up @@ -377,17 +366,6 @@ func (s *RepositorySuite) TestReportDoesntExist() {
s.Require().Nil(err)
}

func (s *RepositorySuite) TestReportFailsDuplicateRow() {
report := Report{
Index: 1,
InputId: 1,
RawData: common.Hex2Bytes("deadbeef"),
}

err := s.database.InsertReport(s.ctx, &report)
s.Require().ErrorContains(err, "duplicate key value")
}

func (s *RepositorySuite) TestReportFailsInputDoesntExist() {
report := Report{
Index: 2,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,7 @@ DROP TABLE IF EXISTS "input";
DROP TABLE IF EXISTS "epoch";
DROP TABLE IF EXISTS "application";

DROP FUNCTION IF EXISTS "f_maxuint64";

DROP TYPE IF EXISTS "InputCompletionStatus";
DROP TYPE IF EXISTS "ApplicationStatus";
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -3,16 +3,31 @@

CREATE TYPE "ApplicationStatus" AS ENUM ('RUNNING', 'NOT RUNNING');

CREATE TYPE "InputCompletionStatus" AS ENUM ('NONE', 'ACCEPTED', 'REJECTED', 'EXCEPTION', 'MACHINE_HALTED', 'CYCLE_LIMIT_EXCEEDED', 'TIME_LIMIT_EXCEEDED', 'PAYLOAD_LENGTH_LIMIT_EXCEEDED');
CREATE TYPE "InputCompletionStatus" AS ENUM (
'NONE',
'ACCEPTED',
'REJECTED',
'EXCEPTION',
'MACHINE_HALTED',
'CYCLE_LIMIT_EXCEEDED',
'TIME_LIMIT_EXCEEDED',
'PAYLOAD_LENGTH_LIMIT_EXCEEDED');

CREATE TYPE "DefaultBlock" AS ENUM ('FINALIZED', 'LATEST', 'PENDING', 'SAFE');

CREATE TYPE "EpochStatus" AS ENUM ('OPEN', 'CLOSED', 'PROCESSED_ALL_INPUTS', 'CLAIM_COMPUTED', 'CLAIM_SUBMITTED', 'CLAIM_ACCEPTED', 'CLAIM_REJECTED');
CREATE TYPE "EpochStatus" AS ENUM (
'OPEN',
'CLOSED',
'PROCESSED_ALL_INPUTS',
'CLAIM_COMPUTED',
'CLAIM_SUBMITTED',
'CLAIM_ACCEPTED',
'CLAIM_REJECTED');

CREATE FUNCTION public.f_maxuint64()
RETURNS NUMERIC(20,0)
LANGUAGE sql IMMUTABLE PARALLEL SAFE AS
'SELECT 18446744073709551615';
CREATE FUNCTION "f_maxuint64"()
RETURNS NUMERIC(20,0)
LANGUAGE sql IMMUTABLE PARALLEL SAFE AS
'SELECT 18446744073709551615';

CREATE TABLE "application"
(
Expand Down Expand Up @@ -74,7 +89,7 @@ CREATE TABLE "output"
CONSTRAINT "output_input_id_fkey" FOREIGN KEY ("input_id") REFERENCES "input"("id")
);

CREATE UNIQUE INDEX "output_idx" ON "output"("index");
CREATE INDEX "output_idx" ON "output"("index");

CREATE TABLE "report"
(
Expand All @@ -86,7 +101,7 @@ CREATE TABLE "report"
CONSTRAINT "report_input_id_fkey" FOREIGN KEY ("input_id") REFERENCES "input"("id")
);

CREATE UNIQUE INDEX "report_idx" ON "report"("index");
CREATE INDEX "report_idx" ON "report"("index");

CREATE TABLE "snapshot"
(
Expand Down
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
-- (c) Cartesi and individual authors (see AUTHORS)
-- SPDX-License-Identifier: Apache-2.0 (see LICENSE)

DROP SCHEMA graphql CASCADE;
DROP SCHEMA graphql CASCADE;
85 changes: 85 additions & 0 deletions internal/repository/schema/schema.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,85 @@
// (c) Cartesi and individual authors (see AUTHORS)
// SPDX-License-Identifier: Apache-2.0 (see LICENSE)

package schema

import (
"embed"
"errors"
"fmt"
"log/slog"

"github.com/golang-migrate/migrate/v4"
mig "github.com/golang-migrate/migrate/v4"
_ "github.com/golang-migrate/migrate/v4/database/postgres"
_ "github.com/golang-migrate/migrate/v4/source/file"
"github.com/golang-migrate/migrate/v4/source/iofs"
)

//go:embed migrations/*
var content embed.FS

const ExpectedVersion uint = 2

type Schema struct {
migrate *mig.Migrate
}

func New(postgresEndpoint string) (*Schema, error) {
driver, err := iofs.New(content, "migrations")
if err != nil {
return nil, err
}

migrate, err := mig.NewWithSourceInstance("iofs", driver, postgresEndpoint)
if err != nil {
return nil, err
}

return &Schema{migrate: migrate}, nil
}

func (s *Schema) Version() (uint, error) {
version, _, err := s.migrate.Version()
if err != nil && errors.Is(err, migrate.ErrNilVersion) {
return version, fmt.Errorf("No valid database schema found")
}
return version, err
}

func (s *Schema) Upgrade() error {
if err := s.migrate.Up(); err != nil && !errors.Is(err, migrate.ErrNoChange) {
return err
}
return nil
}

func (s *Schema) Downgrade() error {
if err := s.migrate.Down(); err != nil && !errors.Is(err, migrate.ErrNoChange) {
return err
}
return nil
}

func (s *Schema) Close() {
source, db := s.migrate.Close()
if source != nil {
slog.Error("Error releasing migration sources", "error", source)
}
if db != nil {
slog.Error("Error closing db connection", "error", db)
}
}

func (s *Schema) ValidateVersion() (uint, error) {
version, err := s.Version()
if err != nil {
return 0, err
}

if version != ExpectedVersion {
format := "Database schema version mismatch. Expected %d but it is %d"
return 0, fmt.Errorf(format, ExpectedVersion, version)
}
return version, nil
}
Loading

0 comments on commit e514801

Please sign in to comment.