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 (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") }