mirror of
				https://github.com/chaisql/chai.git
				synced 2025-10-31 10:56:22 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			105 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			105 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package parser_test
 | |
| 
 | |
| import (
 | |
| 	"testing"
 | |
| 
 | |
| 	"github.com/genjidb/genji/document"
 | |
| 	"github.com/genjidb/genji/internal/database"
 | |
| 	"github.com/genjidb/genji/internal/expr"
 | |
| 	"github.com/genjidb/genji/internal/query/statement"
 | |
| 	"github.com/genjidb/genji/internal/sql/parser"
 | |
| 	"github.com/genjidb/genji/internal/testutil"
 | |
| 	"github.com/genjidb/genji/internal/testutil/assert"
 | |
| 	"github.com/genjidb/genji/types"
 | |
| 	"github.com/stretchr/testify/require"
 | |
| )
 | |
| 
 | |
| func TestParserAlterTable(t *testing.T) {
 | |
| 	tests := []struct {
 | |
| 		name     string
 | |
| 		s        string
 | |
| 		expected statement.Statement
 | |
| 		errored  bool
 | |
| 	}{
 | |
| 		{"Basic", "ALTER TABLE foo RENAME TO bar", statement.AlterStmt{TableName: "foo", NewTableName: "bar"}, false},
 | |
| 		{"With error / missing TABLE keyword", "ALTER foo RENAME TO bar", statement.AlterStmt{}, true},
 | |
| 		{"With error / two identifiers for table name", "ALTER TABLE foo baz RENAME TO bar", statement.AlterStmt{}, true},
 | |
| 		{"With error / two identifiers for new table name", "ALTER TABLE foo RENAME TO bar baz", statement.AlterStmt{}, true},
 | |
| 	}
 | |
| 
 | |
| 	for _, test := range tests {
 | |
| 		t.Run(test.name, func(t *testing.T) {
 | |
| 			q, err := parser.ParseQuery(test.s)
 | |
| 			if test.errored {
 | |
| 				assert.Error(t, err)
 | |
| 				return
 | |
| 			}
 | |
| 			assert.NoError(t, err)
 | |
| 			require.Len(t, q.Statements, 1)
 | |
| 			require.EqualValues(t, test.expected, q.Statements[0])
 | |
| 		})
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func TestParserAlterTableAddField(t *testing.T) {
 | |
| 	tests := []struct {
 | |
| 		name     string
 | |
| 		s        string
 | |
| 		expected statement.Statement
 | |
| 		errored  bool
 | |
| 	}{
 | |
| 		{"Basic", "ALTER TABLE foo ADD FIELD bar", nil, true},
 | |
| 		{"With type", "ALTER TABLE foo ADD FIELD bar integer", statement.AlterTableAddField{
 | |
| 			Info: database.TableInfo{
 | |
| 				TableName: "foo",
 | |
| 				FieldConstraints: []*database.FieldConstraint{
 | |
| 					{
 | |
| 						Path: document.Path(testutil.ParsePath(t, "bar")),
 | |
| 						Type: types.IntegerValue,
 | |
| 					},
 | |
| 				},
 | |
| 			},
 | |
| 		}, false},
 | |
| 		{"With not null", "ALTER TABLE foo ADD FIELD bar NOT NULL", statement.AlterTableAddField{
 | |
| 			Info: database.TableInfo{
 | |
| 				TableName: "foo",
 | |
| 				FieldConstraints: []*database.FieldConstraint{
 | |
| 					{
 | |
| 						Path:      document.Path(testutil.ParsePath(t, "bar")),
 | |
| 						IsNotNull: true,
 | |
| 					},
 | |
| 				},
 | |
| 			},
 | |
| 		}, false},
 | |
| 		{"With primary key", "ALTER TABLE foo ADD FIELD bar PRIMARY KEY", nil, true},
 | |
| 		{"With multiple constraints", "ALTER TABLE foo ADD FIELD bar integer NOT NULL DEFAULT 0", statement.AlterTableAddField{
 | |
| 			Info: database.TableInfo{
 | |
| 				TableName: "foo",
 | |
| 				FieldConstraints: []*database.FieldConstraint{
 | |
| 					{
 | |
| 						Path:         document.Path(testutil.ParsePath(t, "bar")),
 | |
| 						Type:         types.IntegerValue,
 | |
| 						IsNotNull:    true,
 | |
| 						DefaultValue: expr.Constraint(expr.LiteralValue{Value: types.NewIntegerValue(0)}),
 | |
| 					},
 | |
| 				},
 | |
| 			},
 | |
| 		}, false},
 | |
| 		{"With error / missing FIELD keyword", "ALTER TABLE foo ADD bar", nil, true},
 | |
| 		{"With error / missing field name", "ALTER TABLE foo ADD FIELD", nil, true},
 | |
| 	}
 | |
| 
 | |
| 	for _, test := range tests {
 | |
| 		t.Run(test.name, func(t *testing.T) {
 | |
| 			q, err := parser.ParseQuery(test.s)
 | |
| 			if test.errored {
 | |
| 				assert.Error(t, err)
 | |
| 				return
 | |
| 			}
 | |
| 			assert.NoError(t, err)
 | |
| 			require.Len(t, q.Statements, 1)
 | |
| 			require.EqualValues(t, test.expected, q.Statements[0])
 | |
| 		})
 | |
| 	}
 | |
| }
 | 
