From cca13901f1b07b3e3aef432af5eca66fc74c8597 Mon Sep 17 00:00:00 2001 From: sunboyy Date: Tue, 21 May 2024 21:09:03 +0700 Subject: [PATCH] Fix CI to not warn in unrelevant occasions --- .codeclimate.yml | 3 +++ codecov.yml | 2 +- internal/spec/parser.go | 30 +++++++++++++------------- internal/spec/query.go | 17 +++++++++------ internal/spec/update.go | 47 ++++++++++++++++++++++++++++------------- 5 files changed, 62 insertions(+), 37 deletions(-) create mode 100644 .codeclimate.yml diff --git a/.codeclimate.yml b/.codeclimate.yml new file mode 100644 index 0000000..01540c4 --- /dev/null +++ b/.codeclimate.yml @@ -0,0 +1,3 @@ +exclude_patterns: + - "examples/" + - "**/*_test.go" diff --git a/codecov.yml b/codecov.yml index cb4361b..62fd89d 100644 --- a/codecov.yml +++ b/codecov.yml @@ -2,7 +2,7 @@ coverage: status: project: default: - target: 75% + target: 90% patch: default: target: 80% diff --git a/internal/spec/parser.go b/internal/spec/parser.go index 930952e..3421833 100644 --- a/internal/spec/parser.go +++ b/internal/spec/parser.go @@ -136,11 +136,7 @@ func (p interfaceMethodParser) parseFindOperation(tokens []string) (Operation, e return nil, err } - if err := p.validateContextParam(); err != nil { - return nil, err - } - - if err := p.validateQueryFromParams(p.Signature.Params(), 1, querySpec); err != nil { + if err := p.validateQueryOnlyParams(querySpec); err != nil { return nil, err } @@ -310,11 +306,7 @@ func (p interfaceMethodParser) parseDeleteOperation(tokens []string) (Operation, return nil, err } - if err := p.validateContextParam(); err != nil { - return nil, err - } - - if err := p.validateQueryFromParams(p.Signature.Params(), 1, querySpec); err != nil { + if err := p.validateQueryOnlyParams(querySpec); err != nil { return nil, err } @@ -334,11 +326,7 @@ func (p interfaceMethodParser) parseCountOperation(tokens []string) (Operation, return nil, err } - if err := p.validateContextParam(); err != nil { - return nil, err - } - - if err := p.validateQueryFromParams(p.Signature.Params(), 1, querySpec); err != nil { + if err := p.validateQueryOnlyParams(querySpec); err != nil { return nil, err } @@ -385,6 +373,18 @@ func (p interfaceMethodParser) extractIntOrBoolReturns(returns *types.Tuple) (Qu return "", NewUnsupportedReturnError(returns.At(0).Type(), 0) } +func (p interfaceMethodParser) validateQueryOnlyParams(querySpec QuerySpec) error { + if err := p.validateContextParam(); err != nil { + return err + } + + if err := p.validateQueryFromParams(p.Signature.Params(), 1, querySpec); err != nil { + return err + } + + return nil +} + func (p interfaceMethodParser) validateContextParam() error { if p.Signature.Params().Len() == 0 || p.Signature.Params().At(0).Type().String() != "context.Context" { return ErrContextParamRequired diff --git a/internal/spec/query.go b/internal/spec/query.go index 929c4ce..862e04e 100644 --- a/internal/spec/query.go +++ b/internal/spec/query.go @@ -88,15 +88,20 @@ func (p queryParser) parseQuery(rawTokens []string, paramIndex int) (QuerySpec, return QuerySpec{}, ErrQueryRequired } - tokens := rawTokens - if len(tokens) == 1 && tokens[0] == "All" { - return QuerySpec{}, nil + switch rawTokens[0] { + case "All": + if len(rawTokens) == 1 { + return QuerySpec{}, nil + } + case "By": + return p.parseQueryBy(rawTokens, paramIndex) } - if tokens[0] == "By" { - tokens = tokens[1:] - } + return QuerySpec{}, NewInvalidQueryError(rawTokens) +} +func (p queryParser) parseQueryBy(rawTokens []string, paramIndex int) (QuerySpec, error) { + tokens := rawTokens[1:] if len(tokens) == 0 { return QuerySpec{}, NewInvalidQueryError(rawTokens) } diff --git a/internal/spec/update.go b/internal/spec/update.go index e360666..4d3b5bc 100644 --- a/internal/spec/update.go +++ b/internal/spec/update.go @@ -124,6 +124,19 @@ func (p interfaceMethodParser) parseUpdate(tokens []string) (Update, error) { return UpdateModel{}, nil } + updateFields, err := p.parseUpdateFieldsFromTokens(tokens) + if err != nil { + return nil, err + } + + if err := p.validateUpdateFieldsWithParams(updateFields); err != nil { + return nil, err + } + + return updateFields, nil +} + +func (p interfaceMethodParser) parseUpdateFieldsFromTokens(tokens []string) (UpdateFields, error) { updateFieldTokens, ok := splitByAnd(tokens) if !ok { return nil, ErrInvalidUpdateFields @@ -142,21 +155,6 @@ func (p interfaceMethodParser) parseUpdate(tokens []string) (Update, error) { paramIndex += updateField.Operator.NumberOfArguments() } - for _, field := range updateFields { - if p.Signature.Params().Len() < field.ParamIndex+field.Operator.NumberOfArguments() { - return nil, ErrInvalidUpdateFields - } - - expectedType := field.Operator.ArgumentType(field.FieldReference.ReferencedField().Var.Type()) - - for i := 0; i < field.Operator.NumberOfArguments(); i++ { - if !types.Identical(p.Signature.Params().At(field.ParamIndex+i).Type(), expectedType) { - return nil, NewArgumentTypeNotMatchedError(field.FieldReference.ReferencingCode(), expectedType, - p.Signature.Params().At(field.ParamIndex+i).Type()) - } - } - } - return updateFields, nil } @@ -214,3 +212,22 @@ func (p interfaceMethodParser) validateUpdateOperator(referencedType types.Type, } return true } + +func (p interfaceMethodParser) validateUpdateFieldsWithParams(updateFields UpdateFields) error { + for _, field := range updateFields { + if p.Signature.Params().Len() < field.ParamIndex+field.Operator.NumberOfArguments() { + return ErrInvalidUpdateFields + } + + expectedType := field.Operator.ArgumentType(field.FieldReference.ReferencedField().Var.Type()) + + for i := 0; i < field.Operator.NumberOfArguments(); i++ { + if !types.Identical(p.Signature.Params().At(field.ParamIndex+i).Type(), expectedType) { + return NewArgumentTypeNotMatchedError(field.FieldReference.ReferencingCode(), expectedType, + p.Signature.Params().At(field.ParamIndex+i).Type()) + } + } + } + + return nil +}