Skip to content

Commit

Permalink
Merge branch 'main' into mkhuzaima-symmetric-text-padding
Browse files Browse the repository at this point in the history
  • Loading branch information
mkhuzaima authored Dec 28, 2024
2 parents bca9ed9 + 2c54ee2 commit 8ed2e59
Show file tree
Hide file tree
Showing 4 changed files with 73 additions and 6 deletions.
5 changes: 4 additions & 1 deletion ascii/generator.go
Original file line number Diff line number Diff line change
Expand Up @@ -60,7 +60,10 @@ func GenerateASCII(contributionGrid [][]types.ContributionDay, username string,
if day.ContributionCount == -1 {
asciiGrid[dayIdx][weekIdx] = FutureBlock
} else {
normalized := float64(day.ContributionCount) / float64(maxContributions)
normalized := 0.0
if maxContributions != 0 {
normalized = float64(day.ContributionCount) / float64(maxContributions)
}
asciiGrid[dayIdx][weekIdx] = getBlock(normalized, dayIdx, nonZeroCount)
}
}
Expand Down
60 changes: 60 additions & 0 deletions ascii/generator_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -119,3 +119,63 @@ func TestGetBlock(t *testing.T) {
})
}
}

// TestGenerateASCIIZeroContributions tests the GenerateASCII function with zero contributions.
// It verifies that the skyline consists of empty blocks and appropriately handles the header and footer.
func TestGenerateASCIIZeroContributions(t *testing.T) {
tests := []struct {
name string
includeHeaderAndFooter bool
}{
{
name: "Zero contributions without header",
includeHeaderAndFooter: false,
},
{
name: "Zero contributions with header",
includeHeaderAndFooter: true,
},
}

for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
// Create a test grid with zero contributions
grid := makeTestGrid(3, 7)
for i := range grid {
for j := range grid[i] {
grid[i][j].ContributionCount = 0
}
}

// Generate ASCII art
result, err := GenerateASCII(grid, "testuser", 2023, tt.includeHeaderAndFooter, tt.includeHeaderAndFooter)
if err != nil {
t.Fatalf("GenerateASCII() returned an error: %v", err)
}

lines := strings.Split(result, "\n")

// Determine the starting line of the skyline
skylineStart := 0
if tt.includeHeaderAndFooter {
// Assuming HeaderTemplate has a fixed number of lines
headerLines := strings.Count(HeaderTemplate, "\n")
skylineStart = headerLines + 1 // +1 for the additional newline after header
}

// Verify the skyline has at least 7 lines
if len(lines) < skylineStart+7 {
t.Fatalf("Expected at least %d lines for skyline, got %d", skylineStart+7, len(lines))
}

// Check each line of the skyline for empty blocks
for i := skylineStart; i < skylineStart+7; i++ {
for _, ch := range lines[i] {
if ch != EmptyBlock {
t.Errorf("Expected empty block in skyline, got '%c' on line %d", ch, i+1)
}
}
}
})
}
}
10 changes: 7 additions & 3 deletions main.go
Original file line number Diff line number Diff line change
Expand Up @@ -124,7 +124,8 @@ func formatYearRange(startYear, endYear int) string {
if startYear == endYear {
return fmt.Sprintf("%d", startYear)
}
return fmt.Sprintf("%02d-%02d", startYear%100, endYear%100)
// Use YYYY-YY format for multi-year ranges
return fmt.Sprintf("%04d-%02d", startYear, endYear%100)
}

// generateOutputFilename creates a consistent filename for the STL output
Expand Down Expand Up @@ -192,8 +193,11 @@ func generateSkyline(startYear, endYear int, targetUser string, full bool) error
lines := strings.Split(asciiArt, "\n")
gridStart := 0
for i, line := range lines {
if strings.Contains(line, string(ascii.EmptyBlock)) ||
strings.Contains(line, string(ascii.FoundationLow)) {
containsEmptyBlock := strings.Contains(line, string(ascii.EmptyBlock))
containsFoundationLow := strings.Contains(line, string(ascii.FoundationLow))
isNotOnlyEmptyBlocks := strings.Trim(line, string(ascii.EmptyBlock)) != ""

if (containsEmptyBlock || containsFoundationLow) && isNotOnlyEmptyBlocks {
gridStart = i
break
}
Expand Down
4 changes: 2 additions & 2 deletions main_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -39,7 +39,7 @@ func TestFormatYearRange(t *testing.T) {
name: "different years",
startYear: 2020,
endYear: 2024,
want: "20-24",
want: "2020-24",
},
}

Expand Down Expand Up @@ -73,7 +73,7 @@ func TestGenerateOutputFilename(t *testing.T) {
user: "testuser",
startYear: 2020,
endYear: 2024,
want: "testuser-20-24-github-skyline.stl",
want: "testuser-2020-24-github-skyline.stl",
},
}

Expand Down

0 comments on commit 8ed2e59

Please sign in to comment.