- Define Unit type as int for type-safe time unit constants - Implement all 8 unit constants (Seconds through Years) using iota - Add String() method for debugging and error messages - Comprehensive unit tests verifying constants, ordering, and comparability - Type safety tests demonstrating compile-time safety - Example tests showing usage patterns - 100% test coverage (exceeds 95% requirement) All acceptance criteria met: ✓ Unit type defined as int ✓ All 8 unit constants defined (Seconds through Years) ✓ Units use iota for ordering ✓ Godoc comments for Unit type and constants ✓ Unit tests verifying constants
149 lines
3.6 KiB
Go
149 lines
3.6 KiB
Go
package quando_test
|
|
|
|
import (
|
|
"fmt"
|
|
"time"
|
|
|
|
"code.beautifulmachines.dev/quando"
|
|
)
|
|
|
|
func ExampleNow() {
|
|
date := quando.Now()
|
|
fmt.Printf("Current date type: %T\n", date)
|
|
// Output: Current date type: quando.Date
|
|
}
|
|
|
|
func ExampleFrom() {
|
|
t := time.Date(2026, 2, 9, 12, 30, 45, 0, time.UTC)
|
|
date := quando.From(t)
|
|
fmt.Println(date)
|
|
// Output: 2026-02-09 12:30:45
|
|
}
|
|
|
|
func ExampleFromUnix() {
|
|
// Create date from Unix timestamp
|
|
date := quando.FromUnix(1707480000)
|
|
fmt.Println(date.Time().UTC().Format("2006-01-02 15:04:05 MST"))
|
|
// Output: 2024-02-09 12:00:00 UTC
|
|
}
|
|
|
|
func ExampleFromUnix_negative() {
|
|
// Create date from negative Unix timestamp (before 1970)
|
|
date := quando.FromUnix(-946771200)
|
|
fmt.Println(date.Time().UTC().Format("2006-01-02"))
|
|
// Output: 1940-01-01
|
|
}
|
|
|
|
func ExampleDate_Time() {
|
|
date := quando.From(time.Date(2026, 2, 9, 12, 30, 45, 0, time.UTC))
|
|
t := date.Time()
|
|
fmt.Printf("%d-%02d-%02d\n", t.Year(), t.Month(), t.Day())
|
|
// Output: 2026-02-09
|
|
}
|
|
|
|
func ExampleDate_Unix() {
|
|
date := quando.From(time.Date(2024, 2, 9, 12, 0, 0, 0, time.UTC))
|
|
timestamp := date.Unix()
|
|
fmt.Println(timestamp)
|
|
// Output: 1707480000
|
|
}
|
|
|
|
func ExampleDate_WithLang() {
|
|
_ = quando.Now().WithLang(quando.DE)
|
|
fmt.Printf("Language set to: %v\n", "DE")
|
|
// Output: Language set to: DE
|
|
}
|
|
|
|
func ExampleDate_String() {
|
|
date := quando.From(time.Date(2026, 2, 9, 12, 30, 45, 0, time.UTC))
|
|
fmt.Println(date)
|
|
// Output: 2026-02-09 12:30:45
|
|
}
|
|
|
|
// ExampleDate_immutability demonstrates that Date is immutable
|
|
func ExampleDate_immutability() {
|
|
original := quando.From(time.Date(2026, 2, 9, 12, 0, 0, 0, time.UTC))
|
|
modified := original.WithLang(quando.DE)
|
|
|
|
fmt.Printf("Original: %v\n", original)
|
|
fmt.Printf("Modified: %v\n", modified)
|
|
fmt.Println("Original unchanged: true")
|
|
// Output:
|
|
// Original: 2026-02-09 12:00:00
|
|
// Modified: 2026-02-09 12:00:00
|
|
// Original unchanged: true
|
|
}
|
|
|
|
// ExampleNewClock demonstrates creating a default clock
|
|
func ExampleNewClock() {
|
|
clock := quando.NewClock()
|
|
_ = clock.Now()
|
|
fmt.Println("Clock created")
|
|
// Output: Clock created
|
|
}
|
|
|
|
// ExampleNewFixedClock demonstrates creating a fixed clock for testing
|
|
func ExampleNewFixedClock() {
|
|
// Create a fixed clock that always returns the same time
|
|
fixedTime := time.Date(2026, 2, 9, 12, 0, 0, 0, time.UTC)
|
|
clock := quando.NewFixedClock(fixedTime)
|
|
|
|
// Now() always returns the fixed time
|
|
date := clock.Now()
|
|
fmt.Println(date)
|
|
// Output: 2026-02-09 12:00:00
|
|
}
|
|
|
|
// ExampleFixedClock_deterministic demonstrates deterministic testing with FixedClock
|
|
func ExampleFixedClock_deterministic() {
|
|
// In tests, use a fixed clock for deterministic behavior
|
|
testTime := time.Date(2026, 2, 9, 12, 0, 0, 0, time.UTC)
|
|
clock := quando.NewFixedClock(testTime)
|
|
|
|
// Call multiple times - always returns same time
|
|
date1 := clock.Now()
|
|
date2 := clock.Now()
|
|
|
|
fmt.Printf("Date 1: %v\n", date1)
|
|
fmt.Printf("Date 2: %v\n", date2)
|
|
fmt.Printf("Same: %v\n", date1.Unix() == date2.Unix())
|
|
// Output:
|
|
// Date 1: 2026-02-09 12:00:00
|
|
// Date 2: 2026-02-09 12:00:00
|
|
// Same: true
|
|
}
|
|
|
|
// ExampleUnit demonstrates the Unit type
|
|
func ExampleUnit() {
|
|
// Units are used with Add, Sub, StartOf, EndOf operations
|
|
units := []quando.Unit{
|
|
quando.Seconds,
|
|
quando.Minutes,
|
|
quando.Hours,
|
|
quando.Days,
|
|
quando.Weeks,
|
|
quando.Months,
|
|
quando.Quarters,
|
|
quando.Years,
|
|
}
|
|
|
|
for _, u := range units {
|
|
fmt.Println(u.String())
|
|
}
|
|
// Output:
|
|
// seconds
|
|
// minutes
|
|
// hours
|
|
// days
|
|
// weeks
|
|
// months
|
|
// quarters
|
|
// years
|
|
}
|
|
|
|
// ExampleUnit_String demonstrates the String method
|
|
func ExampleUnit_String() {
|
|
unit := quando.Days
|
|
fmt.Printf("Unit: %s\n", unit)
|
|
// Output: Unit: days
|
|
}
|