astro/basic/star_catalog_test.go

63 lines
1.2 KiB
Go
Raw Normal View History

2022-05-06 12:42:01 +08:00
package basic
import (
2022-05-12 15:55:48 +08:00
. "b612.me/astro/tools"
"math"
2022-05-06 12:42:01 +08:00
"testing"
)
func Test_ParseStar(t *testing.T) {
if err := LoadStarData(); err != nil {
2022-05-10 22:24:10 +08:00
t.Fatal(err)
}
2022-05-06 12:42:01 +08:00
for _, v := range stardat {
if _, err := parseStarData(v); err != nil {
2022-05-10 22:24:10 +08:00
t.Fatal(err)
}
2022-05-06 12:42:01 +08:00
}
}
2023-11-19 12:05:22 +08:00
func TestGetStarByChniese(t *testing.T) {
if err := LoadStarData(); err != nil {
2023-11-19 12:05:22 +08:00
t.Fatal(err)
}
2023-11-19 12:05:22 +08:00
sirius, err := StarDataByChinese("天狼星")
if err != nil {
t.Fatal(err)
}
if sirius.HIP != 32349 || sirius.HR != 2491 {
t.Fatal("cannot found star")
}
2023-11-19 12:05:22 +08:00
sirius, err = StarDataByChinese("天狼")
if err != nil {
t.Fatal(err)
}
if sirius.HIP != 32349 || sirius.HR != 2491 {
t.Fatal("cannot found star")
}
}
2022-05-12 15:55:48 +08:00
func TestGetRaDecByDate(t *testing.T) {
if err := LoadStarData(); err != nil {
2022-05-12 15:55:48 +08:00
t.Fatal(err)
}
2022-05-12 15:55:48 +08:00
sirius, err := StarDataByHR(2491)
if err != nil {
t.Fatal(err)
}
ra, dec := sirius.RaDecByJde(2451545.0)
if math.IsNaN(ra) || math.IsInf(ra, 0) || ra < 0 || ra >= 360 {
t.Fatalf("invalid ra: %.12f", ra)
}
if math.IsNaN(dec) || math.IsInf(dec, 0) || dec < -90 || dec > 90 {
t.Fatalf("invalid dec: %.12f", dec)
}
if Format(sirius.Ra/15, 1) == "" || Format(sirius.Dec, 0) == "" {
t.Fatal("unexpected empty formatted catalog coordinates")
}
2022-05-12 15:55:48 +08:00
}