You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
136 lines
3.9 KiB
136 lines
3.9 KiB
// Copyright 2012-present Oliver Eilhard. All rights reserved. |
|
// Use of this source code is governed by a MIT-license. |
|
// See http://olivere.mit-license.org/license.txt for details. |
|
|
|
package elastic |
|
|
|
import ( |
|
"testing" |
|
) |
|
|
|
func TestBulkUpdateRequestSerialization(t *testing.T) { |
|
tests := []struct { |
|
Request BulkableRequest |
|
Expected []string |
|
}{ |
|
// #0 |
|
{ |
|
Request: NewBulkUpdateRequest().Index("index1").Type("tweet").Id("1").Doc(struct { |
|
Counter int64 `json:"counter"` |
|
}{ |
|
Counter: 42, |
|
}), |
|
Expected: []string{ |
|
`{"update":{"_id":"1","_index":"index1","_type":"tweet"}}`, |
|
`{"doc":{"counter":42}}`, |
|
}, |
|
}, |
|
// #1 |
|
{ |
|
Request: NewBulkUpdateRequest().Index("index1").Type("tweet").Id("1"). |
|
RetryOnConflict(3). |
|
DocAsUpsert(true). |
|
Doc(struct { |
|
Counter int64 `json:"counter"` |
|
}{ |
|
Counter: 42, |
|
}), |
|
Expected: []string{ |
|
`{"update":{"_id":"1","_index":"index1","_type":"tweet","_retry_on_conflict":3}}`, |
|
`{"doc":{"counter":42},"doc_as_upsert":true}`, |
|
}, |
|
}, |
|
// #2 |
|
{ |
|
Request: NewBulkUpdateRequest().Index("index1").Type("tweet").Id("1"). |
|
RetryOnConflict(3). |
|
Script(NewScript(`ctx._source.retweets += param1`).Lang("javascript").Param("param1", 42)). |
|
Upsert(struct { |
|
Counter int64 `json:"counter"` |
|
}{ |
|
Counter: 42, |
|
}), |
|
Expected: []string{ |
|
`{"update":{"_id":"1","_index":"index1","_type":"tweet","_retry_on_conflict":3}}`, |
|
`{"upsert":{"counter":42},"script":{"inline":"ctx._source.retweets += param1","lang":"javascript","params":{"param1":42}}}`, |
|
}, |
|
}, |
|
// #3 |
|
{ |
|
Request: NewBulkUpdateRequest().Index("index1").Type("tweet").Id("1").DetectNoop(true).Doc(struct { |
|
Counter int64 `json:"counter"` |
|
}{ |
|
Counter: 42, |
|
}), |
|
Expected: []string{ |
|
`{"update":{"_id":"1","_index":"index1","_type":"tweet"}}`, |
|
`{"detect_noop":true,"doc":{"counter":42}}`, |
|
}, |
|
}, |
|
// #4 |
|
{ |
|
Request: NewBulkUpdateRequest().Index("index1").Type("tweet").Id("1"). |
|
RetryOnConflict(3). |
|
ScriptedUpsert(true). |
|
Script(NewScript(`ctx._source.retweets += param1`).Lang("javascript").Param("param1", 42)). |
|
Upsert(struct { |
|
Counter int64 `json:"counter"` |
|
}{ |
|
Counter: 42, |
|
}), |
|
Expected: []string{ |
|
`{"update":{"_id":"1","_index":"index1","_type":"tweet","_retry_on_conflict":3}}`, |
|
`{"upsert":{"counter":42},"script":{"inline":"ctx._source.retweets += param1","lang":"javascript","params":{"param1":42}},"scripted_upsert":true}`, |
|
}, |
|
}, |
|
} |
|
|
|
for i, test := range tests { |
|
lines, err := test.Request.Source() |
|
if err != nil { |
|
t.Fatalf("#%d: expected no error, got: %v", i, err) |
|
} |
|
if lines == nil { |
|
t.Fatalf("#%d: expected lines, got nil", i) |
|
} |
|
if len(lines) != len(test.Expected) { |
|
t.Fatalf("#%d: expected %d lines, got %d", i, len(test.Expected), len(lines)) |
|
} |
|
for j, line := range lines { |
|
if line != test.Expected[j] { |
|
t.Errorf("#%d: expected line #%d to be\n%s\nbut got:\n%s", i, j, test.Expected[j], line) |
|
} |
|
} |
|
} |
|
} |
|
|
|
var bulkUpdateRequestSerializationResult string |
|
|
|
func BenchmarkBulkUpdateRequestSerialization(b *testing.B) { |
|
b.Run("stdlib", func(b *testing.B) { |
|
r := NewBulkUpdateRequest().Index("index1").Type("doc").Id("1").Doc(struct { |
|
Counter int64 `json:"counter"` |
|
}{ |
|
Counter: 42, |
|
}) |
|
benchmarkBulkUpdateRequestSerialization(b, r.UseEasyJSON(false)) |
|
}) |
|
b.Run("easyjson", func(b *testing.B) { |
|
r := NewBulkUpdateRequest().Index("index1").Type("doc").Id("1").Doc(struct { |
|
Counter int64 `json:"counter"` |
|
}{ |
|
Counter: 42, |
|
}).UseEasyJSON(false) |
|
benchmarkBulkUpdateRequestSerialization(b, r.UseEasyJSON(true)) |
|
}) |
|
} |
|
|
|
func benchmarkBulkUpdateRequestSerialization(b *testing.B, r *BulkUpdateRequest) { |
|
var s string |
|
for n := 0; n < b.N; n++ { |
|
s = r.String() |
|
r.source = nil // Don't let caching spoil the benchmark |
|
} |
|
bulkUpdateRequestSerializationResult = s // ensure the compiler doesn't optimize |
|
b.ReportAllocs() |
|
}
|
|
|