mirror of
				https://github.com/taigrr/yq
				synced 2025-01-18 04:53:17 -08:00 
			
		
		
		
	Minor fixes
This commit is contained in:
		
							parent
							
								
									75044e480c
								
							
						
					
					
						commit
						9bd9468526
					
				| @ -48,3 +48,19 @@ a: cat | |||||||
| b: dog | b: dog | ||||||
| ``` | ``` | ||||||
| 
 | 
 | ||||||
|  | ### Delete matching entries | ||||||
|  | Given a sample.yml file of: | ||||||
|  | ```yaml | ||||||
|  | a: cat | ||||||
|  | b: dog | ||||||
|  | c: bat | ||||||
|  | ``` | ||||||
|  | then | ||||||
|  | ```bash | ||||||
|  | yq eval 'del( .[] | select(. == "*at") )' sample.yml | ||||||
|  | ``` | ||||||
|  | will output | ||||||
|  | ```yaml | ||||||
|  | b: dog | ||||||
|  | ``` | ||||||
|  | 
 | ||||||
|  | |||||||
| @ -37,7 +37,10 @@ func TestJsonEncoderPreservesObjectOrder(t *testing.T) { | |||||||
| 		panic(err) | 		panic(err) | ||||||
| 	} | 	} | ||||||
| 	node := inputs.Front().Value.(*CandidateNode).Node | 	node := inputs.Front().Value.(*CandidateNode).Node | ||||||
| 	jsonEncoder.Encode(node) | 	err = jsonEncoder.Encode(node) | ||||||
|  | 	if err != nil { | ||||||
|  | 		panic(err) | ||||||
|  | 	} | ||||||
| 	writer.Flush() | 	writer.Flush() | ||||||
| 	test.AssertResult(t, expectedJson, output.String()) | 	test.AssertResult(t, expectedJson, output.String()) | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -68,10 +68,7 @@ var Empty = &OperationType{Type: "EMPTY", NumArgs: 50, Handler: EmptyOperator} | |||||||
| 
 | 
 | ||||||
| var RecursiveDescent = &OperationType{Type: "RECURSIVE_DESCENT", NumArgs: 0, Precedence: 50, Handler: RecursiveDescentOperator} | var RecursiveDescent = &OperationType{Type: "RECURSIVE_DESCENT", NumArgs: 0, Precedence: 50, Handler: RecursiveDescentOperator} | ||||||
| 
 | 
 | ||||||
| // not sure yet |  | ||||||
| 
 |  | ||||||
| var Select = &OperationType{Type: "SELECT", NumArgs: 1, Precedence: 50, Handler: SelectOperator} | var Select = &OperationType{Type: "SELECT", NumArgs: 1, Precedence: 50, Handler: SelectOperator} | ||||||
| 
 |  | ||||||
| var DeleteChild = &OperationType{Type: "DELETE", NumArgs: 1, Precedence: 40, Handler: DeleteChildOperator} | var DeleteChild = &OperationType{Type: "DELETE", NumArgs: 1, Precedence: 40, Handler: DeleteChildOperator} | ||||||
| 
 | 
 | ||||||
| // var Exists = &OperationType{Type: "Length", NumArgs: 2, Precedence: 35} | // var Exists = &OperationType{Type: "Length", NumArgs: 2, Precedence: 35} | ||||||
|  | |||||||
| @ -29,6 +29,14 @@ var deleteOperatorScenarios = []expressionScenario{ | |||||||
| 			"D0, P[], (doc)::{a: cat, b: dog}\n", | 			"D0, P[], (doc)::{a: cat, b: dog}\n", | ||||||
| 		}, | 		}, | ||||||
| 	}, | 	}, | ||||||
|  | 	{ | ||||||
|  | 		description: "Delete matching entries", | ||||||
|  | 		document:    `{a: cat, b: dog, c: bat}`, | ||||||
|  | 		expression:  `del( .[] | select(. == "*at") )`, | ||||||
|  | 		expected: []string{ | ||||||
|  | 			"D0, P[], (doc)::{b: dog}\n", | ||||||
|  | 		}, | ||||||
|  | 	}, | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| func TestDeleteOperatorScenarios(t *testing.T) { | func TestDeleteOperatorScenarios(t *testing.T) { | ||||||
|  | |||||||
| @ -35,9 +35,20 @@ func TestPrinterMultipleDocsInSequence(t *testing.T) { | |||||||
| 	el = el.Next() | 	el = el.Next() | ||||||
| 	sample3 := nodeToMap(el.Value.(*CandidateNode)) | 	sample3 := nodeToMap(el.Value.(*CandidateNode)) | ||||||
| 
 | 
 | ||||||
| 	printer.PrintResults(sample1) | 	err = printer.PrintResults(sample1) | ||||||
| 	printer.PrintResults(sample2) | 	if err != nil { | ||||||
| 	printer.PrintResults(sample3) | 		panic(err) | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	err = printer.PrintResults(sample2) | ||||||
|  | 	if err != nil { | ||||||
|  | 		panic(err) | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	err = printer.PrintResults(sample3) | ||||||
|  | 	if err != nil { | ||||||
|  | 		panic(err) | ||||||
|  | 	} | ||||||
| 
 | 
 | ||||||
| 	writer.Flush() | 	writer.Flush() | ||||||
| 	test.AssertResult(t, multiDocSample, output.String()) | 	test.AssertResult(t, multiDocSample, output.String()) | ||||||
| @ -54,7 +65,10 @@ func TestPrinterMultipleDocsInSinglePrint(t *testing.T) { | |||||||
| 		panic(err) | 		panic(err) | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	printer.PrintResults(inputs) | 	err = printer.PrintResults(inputs) | ||||||
|  | 	if err != nil { | ||||||
|  | 		panic(err) | ||||||
|  | 	} | ||||||
| 
 | 
 | ||||||
| 	writer.Flush() | 	writer.Flush() | ||||||
| 	test.AssertResult(t, multiDocSample, output.String()) | 	test.AssertResult(t, multiDocSample, output.String()) | ||||||
| @ -70,7 +84,10 @@ func TestPrinterMultipleDocsJson(t *testing.T) { | |||||||
| 		panic(err) | 		panic(err) | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	printer.PrintResults(inputs) | 	err = printer.PrintResults(inputs) | ||||||
|  | 	if err != nil { | ||||||
|  | 		panic(err) | ||||||
|  | 	} | ||||||
| 
 | 
 | ||||||
| 	expected := `{"a":"banana"} | 	expected := `{"a":"banana"} | ||||||
| {"a":"apple"} | {"a":"apple"} | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user