astro/moon/apsis_test.go
starainrt 3ffdbe0034
feat: 扩展天文计算能力
- 新增日食、月食、本地可见性、中心线、半影区域、SVG 图示与沙罗周期信息
- 新增行星冲合、留、方照、物理星历、视直径、相位、亮肢角、轨道节点等计算
- 新增木星伽利略卫星位置、现象与接触事件计算
- 新增恒星星表、星座判定、自行修正与观测辅助能力
- 新增 coord、formula、orbit、sundial、lite/sun、lite/moon 等扩展包
- 完善农历年号、月相英文别名、视差角、大气质量、折射、日晷与双星计算
- 增加 NASA、JPL Horizons、IMCCE 等回归测试数据与基线测试
- 重构基础算法文件组织,补充大量公开 API 注释和语义回归测试
- 更新中文和英文 README,补充示例、精度说明、SVG 配图
2026-05-01 22:38:44 +08:00

42 lines
1.6 KiB
Go

package moon
import (
"math"
"testing"
"time"
"b612.me/astro/basic"
)
func TestApsisWrappersMatchBasic(t *testing.T) {
perigees := basic.MoonPerigees(2026, time.January)
perigeesWrapped := PerigeesInMonth(2026, time.January)
if len(perigeesWrapped) != len(perigees) {
t.Fatalf("perigee count mismatch: got %d want %d", len(perigeesWrapped), len(perigees))
}
for i, event := range perigees {
wantTime := basic.JDE2DateByZone(event.JDE, time.UTC, false)
if !perigeesWrapped[i].Time.Equal(wantTime) {
t.Fatalf("perigee #%d time mismatch: got %s want %s", i+1, perigeesWrapped[i].Time.Format(time.RFC3339Nano), wantTime.Format(time.RFC3339Nano))
}
if math.Float64bits(perigeesWrapped[i].Distance) != math.Float64bits(event.Distance) {
t.Fatalf("perigee #%d distance mismatch: got %.6f want %.6f", i+1, perigeesWrapped[i].Distance, event.Distance)
}
}
apogees := basic.MoonApogees(2026, time.June)
apogeesWrapped := ApogeesInMonth(2026, time.June)
if len(apogeesWrapped) != len(apogees) {
t.Fatalf("apogee count mismatch: got %d want %d", len(apogeesWrapped), len(apogees))
}
for i, event := range apogees {
wantTime := basic.JDE2DateByZone(event.JDE, time.UTC, false)
if !apogeesWrapped[i].Time.Equal(wantTime) {
t.Fatalf("apogee #%d time mismatch: got %s want %s", i+1, apogeesWrapped[i].Time.Format(time.RFC3339Nano), wantTime.Format(time.RFC3339Nano))
}
if math.Float64bits(apogeesWrapped[i].Distance) != math.Float64bits(event.Distance) {
t.Fatalf("apogee #%d distance mismatch: got %.6f want %.6f", i+1, apogeesWrapped[i].Distance, event.Distance)
}
}
}