Package testing
selain berisikan tools untuk testing juga berisikan tools untuk benchmarking. Cara pembuatan benchmark sendiri cukup mudah yaitu dengan membuat fungsi yang namanya diawali dengan Benchmark
dan parameternya bertipe *testing.B
.
Membuat program pada file main.go
Buat program seperti dibawah ini, yang mana pada program ini terdapat Struct Tabung yang nantinya terdiri dari beberapa method, diantaranya sebagai berikut.
Pertama siapkan terlebih dahulu sebuah struct Tabung
. Variabel object hasil struct ini nantinya kita gunakan sebagai bahan testing.
package main
import "math"
type Tabung struct {
Jarijari, Tinggi float64
}
func (t Tabung) Volume() float64 {
return math.Phi * math.Pow(t.Jarijari, 2) * t.Tinggi
}
func (t Tabung) Luas() float64 {
return 2 * math.Phi * t.Jarijari * (t.Jarijari + t.Tinggi)
}
func (t Tabung) KelilingAlas() float64 {
return 2 * math.Phi * t.Jarijari
}
Lalu, kita akan mengetes performa perhitungan luas tabung. Siapkan fungsi dengan nama BenchmarkHitungLuas()
dengan isi adalah kode berikut.
func BenchmarkHitungLuas(b *testing.B) {
tabung := Tabung{Jarijari: 7, Tinggi: 10}
for i := 0; i < b.N; i++ {
tabung.Luas()
}
}
Jalankan test menggunakan argument -bench=.
, argumen ini digunakan untuk menandai bahwa selain testing
terdapat juga benchmark
yang perlu diuji.
➜ tabung git:(main) ✗ go test -v -bench=.
=== RUN TestTabung_Volume
=== RUN TestTabung_Volume/testing_hitung_volume
--- PASS: TestTabung_Volume (0.00s)
--- PASS: TestTabung_Volume/testing_hitung_volume (0.00s)
=== RUN TestTabung_Luas
=== RUN TestTabung_Luas/testing_hitung_luas_permukaan
--- PASS: TestTabung_Luas (0.00s)
--- PASS: TestTabung_Luas/testing_hitung_luas_permukaan (0.00s)
=== RUN TestTabung_KelilingAlas
=== RUN TestTabung_KelilingAlas/testing_hitung_keliling_alas
--- PASS: TestTabung_KelilingAlas (0.00s)
--- PASS: TestTabung_KelilingAlas/testing_hitung_keliling_alas (0.00s)
goos: darwin
goarch: arm64
pkg: github.com/santekno/tabung
BenchmarkHitungLuas
BenchmarkHitungLuas-8 1000000000 0.3317 ns/op
PASS
ok github.com/santekno/tabung 2.557s
Cara membaca hasil Benchmark
Arti dari 1000000000 0.3317 ns/op adalah, fungsi di atas di-test sebanyak 1 miliar kali, hasilnya membutuhkan waktu rata-rata 0.3317 nano detik untuk run satu fungsi.
Cara Membuat Unit Test Pada Golang
Artikel Terhangat
50 Role-based Authorization di GraphQL
08 Aug 2025
72. Generate Swagger/OpenAPI dari Protobuf
08 Aug 2025
49 Autentikasi Resolver Berdasarkan Context
08 Aug 2025
48 Menyimpan dan Mengecek Token JWT
08 Aug 2025
Rental Mobil Kapasitas 7 Seat Bandung Murah
08 Aug 2025
47 Membuat Mutation Login dan Signup
08 Aug 2025

50 Role-based Authorization di GraphQL

72. Generate Swagger/OpenAPI dari Protobuf

49 Autentikasi Resolver Berdasarkan Context

48 Menyimpan dan Mengecek Token JWT

Rental Mobil Kapasitas 7 Seat Bandung Murah
