本文整理匯總了Golang中github.com/getgauge/gauge/parser.SpecParser類的典型用法代碼示例。如果您正苦於以下問題:Golang SpecParser類的具體用法?Golang SpecParser怎麽用?Golang SpecParser使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。
在下文中一共展示了SpecParser類的9個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。
示例1: TestCreateSkippedSpecResultWithScenarios
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")
}
示例2: TestScenarioIndexFilterWithWrongScenarioIndex
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)
}
示例3: TestScenarioIndexFilterForSingleScenarioSpec
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")
}
示例4: TestResolveNestedConceptToProtoConceptItem
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")
}
示例5: getRefactorAgent
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
}
示例6: TestScenarioIndexFilterFirstScenario
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")
}
示例7: TestResolveNestedConceptToProtoConceptItem
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")
}
示例8: TestResolveToProtoConceptItemWithDataTable
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")
}
示例9: TestResolveToProtoConceptItemWithDataTable
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")
}