func (s *MySuite) TestCreateSkippedSpecResultWithScenarios(c *C) { specText := SpecBuilder().specHeading("A spec heading"). scenarioHeading("First scenario"). step("create user \"456\" \"foo\" and \"9900\""). String() spec, _ := new(parser.SpecParser).Parse(specText, gauge.NewConceptDictionary()) spec.FileName = "FILE" specExecutor := newSpecExecutor(spec, nil, nil, indexRange{start: 0, end: 0}, nil, nil) specExecutor.errMap = &validationErrMaps{make(map[*gauge.Specification][]*stepValidationError), make(map[*gauge.Scenario][]*stepValidationError), make(map[*gauge.Step]*stepValidationError)} specExecutor.consoleReporter = reporter.Current() specExecutor.specResult = &result.SpecResult{ProtoSpec: &gauge_messages.ProtoSpec{}} result := specExecutor.createSkippedSpecResult(fmt.Errorf("ERROR")) c.Assert(result.IsFailed, Equals, false) c.Assert(result.Skipped, Equals, true) c.Assert(len(specExecutor.errMap.specErrs[spec]), Equals, 1) c.Assert(specExecutor.errMap.specErrs[spec][0].Error(), Equals, "ERROR") c.Assert(specExecutor.errMap.specErrs[spec][0].fileName, Equals, "FILE") c.Assert(specExecutor.errMap.specErrs[spec][0].step.LineNo, Equals, 1) c.Assert(specExecutor.errMap.specErrs[spec][0].step.LineText, Equals, "A spec heading") c.Assert(len(specExecutor.errMap.scenarioErrs[spec.Scenarios[0]]), Equals, 1) c.Assert(specExecutor.errMap.scenarioErrs[spec.Scenarios[0]][0].Error(), Equals, "ERROR") c.Assert(specExecutor.errMap.scenarioErrs[spec.Scenarios[0]][0].fileName, Equals, "FILE") c.Assert(specExecutor.errMap.scenarioErrs[spec.Scenarios[0]][0].step.LineNo, Equals, 1) c.Assert(specExecutor.errMap.scenarioErrs[spec.Scenarios[0]][0].step.LineText, Equals, "A spec heading") }
func (s *MySuite) TestScenarioIndexFilterWithWrongScenarioIndex(c *C) { specText := SpecBuilder().specHeading("spec heading"). scenarioHeading("First scenario"). step("a step").String() spec, parseResult := new(parser.SpecParser).Parse(specText, new(parser.ConceptDictionary)) c.Assert(parseResult.Ok, Equals, true) spec.Filter(newScenarioIndexFilterToRetain(1)) c.Assert(len(spec.Scenarios), Equals, 0) }
func (s *MySuite) TestScenarioIndexFilterForSingleScenarioSpec(c *C) { specText := SpecBuilder().specHeading("spec heading"). scenarioHeading("First scenario"). step("a step").String() spec, parseResult := new(parser.SpecParser).Parse(specText, new(parser.ConceptDictionary)) c.Assert(parseResult.Ok, Equals, true) spec.Filter(newScenarioIndexFilterToRetain(0)) c.Assert(len(spec.Scenarios), Equals, 1) c.Assert(spec.Scenarios[0].Heading.Value, Equals, "First scenario") }
func (s *MySuite) TestResolveNestedConceptToProtoConceptItem(c *C) { conceptDictionary := new(parser.ConceptDictionary) specText := SpecBuilder().specHeading("A spec heading"). scenarioHeading("First scenario"). step("create user \"456\" \"foo\" and \"9900\""). String() conceptText := SpecBuilder(). specHeading("create user <user-id> <user-name> and <user-phone>"). step("assign id <user-id> and name <user-name>"). step("assign phone <user-phone>"). specHeading("assign id <userid> and name <username>"). step("add id <userid>"). step("add name <username>").String() concepts, _ := new(parser.ConceptParser).Parse(conceptText) conceptDictionary.Add(concepts, "file.cpt") specParser := new(parser.SpecParser) spec, _ := specParser.Parse(specText, conceptDictionary) specExecutor := newSpecExecutor(spec, nil, nil, indexRange{start: 0, end: 0}, nil, nil) specExecutor.errMap = &validationErrMaps{make(map[*parser.Specification][]*stepValidationError), make(map[*parser.Scenario][]*stepValidationError), make(map[*parser.Step]*stepValidationError)} protoConcept := specExecutor.resolveToProtoConceptItem(*spec.Scenarios[0].Steps[0]).GetConcept() checkConceptParameterValuesInOrder(c, protoConcept, "456", "foo", "9900") c.Assert(protoConcept.GetSteps()[0].GetItemType(), Equals, gauge_messages.ProtoItem_Concept) nestedConcept := protoConcept.GetSteps()[0].GetConcept() checkConceptParameterValuesInOrder(c, nestedConcept, "456", "foo") firstNestedStep := nestedConcept.GetSteps()[0].GetStep() params := getParameters(firstNestedStep.GetFragments()) c.Assert(1, Equals, len(params)) c.Assert(params[0].GetParameterType(), Equals, gauge_messages.Parameter_Dynamic) c.Assert(params[0].GetValue(), Equals, "456") secondNestedStep := nestedConcept.GetSteps()[1].GetStep() params = getParameters(secondNestedStep.GetFragments()) c.Assert(1, Equals, len(params)) c.Assert(params[0].GetParameterType(), Equals, gauge_messages.Parameter_Dynamic) c.Assert(params[0].GetValue(), Equals, "foo") c.Assert(protoConcept.GetSteps()[1].GetItemType(), Equals, gauge_messages.ProtoItem_Step) secondStepInConcept := protoConcept.GetSteps()[1].GetStep() params = getParameters(secondStepInConcept.GetFragments()) c.Assert(1, Equals, len(params)) c.Assert(params[0].GetParameterType(), Equals, gauge_messages.Parameter_Dynamic) c.Assert(params[0].GetValue(), Equals, "9900") }
func getRefactorAgent(oldStepText, newStepText string, startChan *runner.StartChannels) (*rephraseRefactorer, error) { specParser := new(parser.SpecParser) stepTokens, err := specParser.GenerateTokens("* " + oldStepText + "\n" + "*" + newStepText) if err != nil { return nil, err } spec := &parser.Specification{} steps := make([]*parser.Step, 0) for _, stepToken := range stepTokens { step, parseDetails := spec.CreateStepUsingLookup(stepToken, nil) if parseDetails != nil && parseDetails.Error != nil { return nil, parseDetails.Error } steps = append(steps, step) } return &rephraseRefactorer{oldStep: steps[0], newStep: steps[1], startChan: startChan}, nil }
func (s *MySuite) TestScenarioIndexFilterFirstScenario(c *C) { specText := SpecBuilder().specHeading("spec heading"). scenarioHeading("First scenario"). step("a step"). scenarioHeading("Second scenario"). step("second step"). scenarioHeading("Third scenario"). step("third user"). scenarioHeading("Fourth scenario"). step("Fourth user").String() spec, parseResult := new(parser.SpecParser).Parse(specText, gauge.NewConceptDictionary()) c.Assert(parseResult.Ok, Equals, true) spec.Filter(newScenarioIndexFilterToRetain(0)) c.Assert(len(spec.Scenarios), Equals, 1) c.Assert(spec.Scenarios[0].Heading.Value, Equals, "First scenario") }
func (s *MySuite) TestResolveNestedConceptToProtoConceptItem(c *C) { conceptDictionary := gauge.NewConceptDictionary() specText := SpecBuilder().specHeading("A spec heading"). scenarioHeading("First scenario"). step("create user \"456\" \"foo\" and \"9900\""). String() path, _ := filepath.Abs(filepath.Join("testdata", "concept.cpt")) parser.AddConcepts(path, conceptDictionary) specParser := new(parser.SpecParser) spec, _ := specParser.Parse(specText, conceptDictionary) specExecutor := newSpecExecutor(spec, nil, nil, indexRange{start: 0, end: 0}, nil, nil) specExecutor.errMap = getValidationErrorMap() protoConcept := specExecutor.resolveToProtoConceptItem(*spec.Scenarios[0].Steps[0]).GetConcept() checkConceptParameterValuesInOrder(c, protoConcept, "456", "foo", "9900") c.Assert(protoConcept.GetSteps()[0].GetItemType(), Equals, gauge_messages.ProtoItem_Concept) nestedConcept := protoConcept.GetSteps()[0].GetConcept() checkConceptParameterValuesInOrder(c, nestedConcept, "456", "foo") firstNestedStep := nestedConcept.GetSteps()[0].GetStep() params := getParameters(firstNestedStep.GetFragments()) c.Assert(1, Equals, len(params)) c.Assert(params[0].GetParameterType(), Equals, gauge_messages.Parameter_Dynamic) c.Assert(params[0].GetValue(), Equals, "456") secondNestedStep := nestedConcept.GetSteps()[1].GetStep() params = getParameters(secondNestedStep.GetFragments()) c.Assert(1, Equals, len(params)) c.Assert(params[0].GetParameterType(), Equals, gauge_messages.Parameter_Dynamic) c.Assert(params[0].GetValue(), Equals, "foo") c.Assert(protoConcept.GetSteps()[1].GetItemType(), Equals, gauge_messages.ProtoItem_Step) secondStepInConcept := protoConcept.GetSteps()[1].GetStep() params = getParameters(secondStepInConcept.GetFragments()) c.Assert(1, Equals, len(params)) c.Assert(params[0].GetParameterType(), Equals, gauge_messages.Parameter_Dynamic) c.Assert(params[0].GetValue(), Equals, "9900") }
func (s *MySuite) TestResolveToProtoConceptItemWithDataTable(c *C) { conceptDictionary := new(parser.ConceptDictionary) specText := SpecBuilder().specHeading("A spec heading"). tableHeader("id", "name", "phone"). tableHeader("123", "foo", "8800"). tableHeader("666", "bar", "9900"). scenarioHeading("First scenario"). step("create user <id> <name> and <phone>"). String() conceptText := SpecBuilder(). specHeading("create user <user-id> <user-name> and <user-phone>"). step("assign id <user-id> and name <user-name>"). step("assign phone <user-phone>"). specHeading("assign id <userid> and name <username>"). step("add id <userid>"). step("add name <username>").String() concepts, _ := new(parser.ConceptParser).Parse(conceptText) conceptDictionary.Add(concepts, "file.cpt") parser := new(parser.SpecParser) spec, _ := parser.Parse(specText, conceptDictionary) specExecutor := newSpecExecutor(spec, nil, nil, indexRange{start: 0, end: 0}, nil) // For first row specExecutor.currentTableRow = 0 protoConcept := specExecutor.resolveToProtoConceptItem(*spec.Scenarios[0].Steps[0]).GetConcept() checkConceptParameterValuesInOrder(c, protoConcept, "123", "foo", "8800") c.Assert(protoConcept.GetSteps()[0].GetItemType(), Equals, gauge_messages.ProtoItem_Concept) nestedConcept := protoConcept.GetSteps()[0].GetConcept() checkConceptParameterValuesInOrder(c, nestedConcept, "123", "foo") firstNestedStep := nestedConcept.GetSteps()[0].GetStep() params := getParameters(firstNestedStep.GetFragments()) c.Assert(1, Equals, len(params)) c.Assert(params[0].GetParameterType(), Equals, gauge_messages.Parameter_Dynamic) c.Assert(params[0].GetValue(), Equals, "123") secondNestedStep := nestedConcept.GetSteps()[1].GetStep() params = getParameters(secondNestedStep.GetFragments()) c.Assert(1, Equals, len(params)) c.Assert(params[0].GetParameterType(), Equals, gauge_messages.Parameter_Dynamic) c.Assert(params[0].GetValue(), Equals, "foo") c.Assert(protoConcept.GetSteps()[1].GetItemType(), Equals, gauge_messages.ProtoItem_Step) secondStepInConcept := protoConcept.GetSteps()[1].GetStep() params = getParameters(secondStepInConcept.GetFragments()) c.Assert(1, Equals, len(params)) c.Assert(params[0].GetParameterType(), Equals, gauge_messages.Parameter_Dynamic) c.Assert(params[0].GetValue(), Equals, "8800") // For second row specExecutor.currentTableRow = 1 protoConcept = specExecutor.resolveToProtoConceptItem(*spec.Scenarios[0].Steps[0]).GetConcept() c.Assert(protoConcept.GetSteps()[0].GetItemType(), Equals, gauge_messages.ProtoItem_Concept) checkConceptParameterValuesInOrder(c, protoConcept, "666", "bar", "9900") nestedConcept = protoConcept.GetSteps()[0].GetConcept() checkConceptParameterValuesInOrder(c, nestedConcept, "666", "bar") firstNestedStep = nestedConcept.GetSteps()[0].GetStep() params = getParameters(firstNestedStep.GetFragments()) c.Assert(1, Equals, len(params)) c.Assert(params[0].GetParameterType(), Equals, gauge_messages.Parameter_Dynamic) c.Assert(params[0].GetValue(), Equals, "666") secondNestedStep = nestedConcept.GetSteps()[1].GetStep() params = getParameters(secondNestedStep.GetFragments()) c.Assert(1, Equals, len(params)) c.Assert(params[0].GetParameterType(), Equals, gauge_messages.Parameter_Dynamic) c.Assert(params[0].GetValue(), Equals, "bar") c.Assert(protoConcept.GetSteps()[1].GetItemType(), Equals, gauge_messages.ProtoItem_Step) secondStepInConcept = protoConcept.GetSteps()[1].GetStep() params = getParameters(secondStepInConcept.GetFragments()) c.Assert(1, Equals, len(params)) c.Assert(params[0].GetParameterType(), Equals, gauge_messages.Parameter_Dynamic) c.Assert(params[0].GetValue(), Equals, "9900") }
func (s *MySuite) TestResolveToProtoConceptItemWithDataTable(c *C) { conceptDictionary := gauge.NewConceptDictionary() specText := SpecBuilder().specHeading("A spec heading"). tableHeader("id", "name", "phone"). tableHeader("123", "foo", "8800"). tableHeader("666", "bar", "9900"). scenarioHeading("First scenario"). step("create user <id> <name> and <phone>"). String() path, _ := filepath.Abs(filepath.Join("testdata", "concept.cpt")) parser.AddConcepts(path, conceptDictionary) specParser := new(parser.SpecParser) spec, _ := specParser.Parse(specText, conceptDictionary) specExecutor := newSpecExecutor(spec, nil, nil, indexRange{start: 0, end: 0}, nil, nil) // For first row specExecutor.currentTableRow = 0 specExecutor.errMap = &validationErrMaps{make(map[*gauge.Specification][]*stepValidationError), make(map[*gauge.Scenario][]*stepValidationError), make(map[*gauge.Step]*stepValidationError)} protoConcept := specExecutor.resolveToProtoConceptItem(*spec.Scenarios[0].Steps[0]).GetConcept() checkConceptParameterValuesInOrder(c, protoConcept, "123", "foo", "8800") c.Assert(protoConcept.GetSteps()[0].GetItemType(), Equals, gauge_messages.ProtoItem_Concept) nestedConcept := protoConcept.GetSteps()[0].GetConcept() checkConceptParameterValuesInOrder(c, nestedConcept, "123", "foo") firstNestedStep := nestedConcept.GetSteps()[0].GetStep() params := getParameters(firstNestedStep.GetFragments()) c.Assert(1, Equals, len(params)) c.Assert(params[0].GetParameterType(), Equals, gauge_messages.Parameter_Dynamic) c.Assert(params[0].GetValue(), Equals, "123") secondNestedStep := nestedConcept.GetSteps()[1].GetStep() params = getParameters(secondNestedStep.GetFragments()) c.Assert(1, Equals, len(params)) c.Assert(params[0].GetParameterType(), Equals, gauge_messages.Parameter_Dynamic) c.Assert(params[0].GetValue(), Equals, "foo") c.Assert(protoConcept.GetSteps()[1].GetItemType(), Equals, gauge_messages.ProtoItem_Step) secondStepInConcept := protoConcept.GetSteps()[1].GetStep() params = getParameters(secondStepInConcept.GetFragments()) c.Assert(1, Equals, len(params)) c.Assert(params[0].GetParameterType(), Equals, gauge_messages.Parameter_Dynamic) c.Assert(params[0].GetValue(), Equals, "8800") // For second row specExecutor.currentTableRow = 1 protoConcept = specExecutor.resolveToProtoConceptItem(*spec.Scenarios[0].Steps[0]).GetConcept() c.Assert(protoConcept.GetSteps()[0].GetItemType(), Equals, gauge_messages.ProtoItem_Concept) checkConceptParameterValuesInOrder(c, protoConcept, "666", "bar", "9900") nestedConcept = protoConcept.GetSteps()[0].GetConcept() checkConceptParameterValuesInOrder(c, nestedConcept, "666", "bar") firstNestedStep = nestedConcept.GetSteps()[0].GetStep() params = getParameters(firstNestedStep.GetFragments()) c.Assert(1, Equals, len(params)) c.Assert(params[0].GetParameterType(), Equals, gauge_messages.Parameter_Dynamic) c.Assert(params[0].GetValue(), Equals, "666") secondNestedStep = nestedConcept.GetSteps()[1].GetStep() params = getParameters(secondNestedStep.GetFragments()) c.Assert(1, Equals, len(params)) c.Assert(params[0].GetParameterType(), Equals, gauge_messages.Parameter_Dynamic) c.Assert(params[0].GetValue(), Equals, "bar") c.Assert(protoConcept.GetSteps()[1].GetItemType(), Equals, gauge_messages.ProtoItem_Step) secondStepInConcept = protoConcept.GetSteps()[1].GetStep() params = getParameters(secondStepInConcept.GetFragments()) c.Assert(1, Equals, len(params)) c.Assert(params[0].GetParameterType(), Equals, gauge_messages.Parameter_Dynamic) c.Assert(params[0].GetValue(), Equals, "9900") }