mirror of
https://github.com/miniflux/v2.git
synced 2024-09-16 07:50:37 +02:00
237 lines
3.8 KiB
Go
237 lines
3.8 KiB
Go
|
package goquery
|
||
|
|
||
|
import (
|
||
|
"testing"
|
||
|
)
|
||
|
|
||
|
func BenchmarkFilter(b *testing.B) {
|
||
|
var n int
|
||
|
|
||
|
b.StopTimer()
|
||
|
sel := DocW().Find("li")
|
||
|
b.StartTimer()
|
||
|
for i := 0; i < b.N; i++ {
|
||
|
if n == 0 {
|
||
|
n = sel.Filter(".toclevel-1").Length()
|
||
|
} else {
|
||
|
sel.Filter(".toclevel-1")
|
||
|
}
|
||
|
}
|
||
|
if n != 13 {
|
||
|
b.Fatalf("want 13, got %d", n)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func BenchmarkNot(b *testing.B) {
|
||
|
var n int
|
||
|
|
||
|
b.StopTimer()
|
||
|
sel := DocW().Find("li")
|
||
|
b.StartTimer()
|
||
|
for i := 0; i < b.N; i++ {
|
||
|
if n == 0 {
|
||
|
n = sel.Not(".toclevel-2").Length()
|
||
|
} else {
|
||
|
sel.Filter(".toclevel-2")
|
||
|
}
|
||
|
}
|
||
|
if n != 371 {
|
||
|
b.Fatalf("want 371, got %d", n)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func BenchmarkFilterFunction(b *testing.B) {
|
||
|
var n int
|
||
|
|
||
|
b.StopTimer()
|
||
|
sel := DocW().Find("li")
|
||
|
f := func(i int, s *Selection) bool {
|
||
|
return len(s.Get(0).Attr) > 0
|
||
|
}
|
||
|
b.StartTimer()
|
||
|
for i := 0; i < b.N; i++ {
|
||
|
if n == 0 {
|
||
|
n = sel.FilterFunction(f).Length()
|
||
|
} else {
|
||
|
sel.FilterFunction(f)
|
||
|
}
|
||
|
}
|
||
|
if n != 112 {
|
||
|
b.Fatalf("want 112, got %d", n)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func BenchmarkNotFunction(b *testing.B) {
|
||
|
var n int
|
||
|
|
||
|
b.StopTimer()
|
||
|
sel := DocW().Find("li")
|
||
|
f := func(i int, s *Selection) bool {
|
||
|
return len(s.Get(0).Attr) > 0
|
||
|
}
|
||
|
b.StartTimer()
|
||
|
for i := 0; i < b.N; i++ {
|
||
|
if n == 0 {
|
||
|
n = sel.NotFunction(f).Length()
|
||
|
} else {
|
||
|
sel.NotFunction(f)
|
||
|
}
|
||
|
}
|
||
|
if n != 261 {
|
||
|
b.Fatalf("want 261, got %d", n)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func BenchmarkFilterNodes(b *testing.B) {
|
||
|
var n int
|
||
|
|
||
|
b.StopTimer()
|
||
|
sel := DocW().Find("li")
|
||
|
sel2 := DocW().Find(".toclevel-2")
|
||
|
nodes := sel2.Nodes
|
||
|
b.StartTimer()
|
||
|
for i := 0; i < b.N; i++ {
|
||
|
if n == 0 {
|
||
|
n = sel.FilterNodes(nodes...).Length()
|
||
|
} else {
|
||
|
sel.FilterNodes(nodes...)
|
||
|
}
|
||
|
}
|
||
|
if n != 2 {
|
||
|
b.Fatalf("want 2, got %d", n)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func BenchmarkNotNodes(b *testing.B) {
|
||
|
var n int
|
||
|
|
||
|
b.StopTimer()
|
||
|
sel := DocW().Find("li")
|
||
|
sel2 := DocW().Find(".toclevel-1")
|
||
|
nodes := sel2.Nodes
|
||
|
b.StartTimer()
|
||
|
for i := 0; i < b.N; i++ {
|
||
|
if n == 0 {
|
||
|
n = sel.NotNodes(nodes...).Length()
|
||
|
} else {
|
||
|
sel.NotNodes(nodes...)
|
||
|
}
|
||
|
}
|
||
|
if n != 360 {
|
||
|
b.Fatalf("want 360, got %d", n)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func BenchmarkFilterSelection(b *testing.B) {
|
||
|
var n int
|
||
|
|
||
|
b.StopTimer()
|
||
|
sel := DocW().Find("li")
|
||
|
sel2 := DocW().Find(".toclevel-2")
|
||
|
b.StartTimer()
|
||
|
for i := 0; i < b.N; i++ {
|
||
|
if n == 0 {
|
||
|
n = sel.FilterSelection(sel2).Length()
|
||
|
} else {
|
||
|
sel.FilterSelection(sel2)
|
||
|
}
|
||
|
}
|
||
|
if n != 2 {
|
||
|
b.Fatalf("want 2, got %d", n)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func BenchmarkNotSelection(b *testing.B) {
|
||
|
var n int
|
||
|
|
||
|
b.StopTimer()
|
||
|
sel := DocW().Find("li")
|
||
|
sel2 := DocW().Find(".toclevel-1")
|
||
|
b.StartTimer()
|
||
|
for i := 0; i < b.N; i++ {
|
||
|
if n == 0 {
|
||
|
n = sel.NotSelection(sel2).Length()
|
||
|
} else {
|
||
|
sel.NotSelection(sel2)
|
||
|
}
|
||
|
}
|
||
|
if n != 360 {
|
||
|
b.Fatalf("want 360, got %d", n)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func BenchmarkHas(b *testing.B) {
|
||
|
var n int
|
||
|
|
||
|
b.StopTimer()
|
||
|
sel := DocW().Find("h2")
|
||
|
b.StartTimer()
|
||
|
for i := 0; i < b.N; i++ {
|
||
|
if n == 0 {
|
||
|
n = sel.Has(".editsection").Length()
|
||
|
} else {
|
||
|
sel.Has(".editsection")
|
||
|
}
|
||
|
}
|
||
|
if n != 13 {
|
||
|
b.Fatalf("want 13, got %d", n)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func BenchmarkHasNodes(b *testing.B) {
|
||
|
var n int
|
||
|
|
||
|
b.StopTimer()
|
||
|
sel := DocW().Find("li")
|
||
|
sel2 := DocW().Find(".tocnumber")
|
||
|
nodes := sel2.Nodes
|
||
|
b.StartTimer()
|
||
|
for i := 0; i < b.N; i++ {
|
||
|
if n == 0 {
|
||
|
n = sel.HasNodes(nodes...).Length()
|
||
|
} else {
|
||
|
sel.HasNodes(nodes...)
|
||
|
}
|
||
|
}
|
||
|
if n != 15 {
|
||
|
b.Fatalf("want 15, got %d", n)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func BenchmarkHasSelection(b *testing.B) {
|
||
|
var n int
|
||
|
|
||
|
b.StopTimer()
|
||
|
sel := DocW().Find("li")
|
||
|
sel2 := DocW().Find(".tocnumber")
|
||
|
b.StartTimer()
|
||
|
for i := 0; i < b.N; i++ {
|
||
|
if n == 0 {
|
||
|
n = sel.HasSelection(sel2).Length()
|
||
|
} else {
|
||
|
sel.HasSelection(sel2)
|
||
|
}
|
||
|
}
|
||
|
if n != 15 {
|
||
|
b.Fatalf("want 15, got %d", n)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func BenchmarkEnd(b *testing.B) {
|
||
|
var n int
|
||
|
|
||
|
b.StopTimer()
|
||
|
sel := DocW().Find("li").Has(".tocnumber")
|
||
|
b.StartTimer()
|
||
|
for i := 0; i < b.N; i++ {
|
||
|
if n == 0 {
|
||
|
n = sel.End().Length()
|
||
|
} else {
|
||
|
sel.End()
|
||
|
}
|
||
|
}
|
||
|
if n != 373 {
|
||
|
b.Fatalf("wnat 373, got %d", n)
|
||
|
}
|
||
|
}
|