func (specInfoGatherer *SpecInfoGatherer) addConcept(fileName string) { logger.ApiLog.Info("Concept added/modified: %s", fileName) if err := parser.AddConcepts(fileName, specInfoGatherer.getDictionary()); err != nil { logger.ApiLog.Error("Concept parse failure: %s %s", fileName, err) return } specInfoGatherer.findAllStepsFromConcepts() specInfoGatherer.updateAllStepsList() }
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 = &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, "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 := 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") }