// Copyright 2016 The Gitea Authors. All rights reserved.
// Use of this source code is governed by a MIT-style
// license that can be found in the LICENSE file.

package models

import (
	"fmt"
	"testing"

	"code.gitea.io/git"
)

func BenchmarkGetCommitGraph(b *testing.B) {

	currentRepo, err := git.OpenRepository(".")
	if err != nil {
		b.Error("Could not open repository")
	}

	for i := 0; i < b.N; i++ {
		graph, err := GetCommitGraph(currentRepo)
		if err != nil {
			b.Error("Could get commit graph")
		}

		if len(graph) < 100 {
			b.Error("Should get 100 log lines.")
		}
	}
}

func BenchmarkParseCommitString(b *testing.B) {
	testString := "* DATA:||4e61bacab44e9b4730e44a6615d04098dd3a8eaf|2016-12-20 21:10:41 +0100|Kjell Kvinge|kjell@kvinge.biz|4e61bac|Add route for graph"

	for i := 0; i < b.N; i++ {
		graphItem, err := graphItemFromString(testString, nil)
		if err != nil {
			b.Error("could not parse teststring")
		}

		if graphItem.Author != "Kjell Kvinge" {
			b.Error("Did not get expected data")
		}
	}
}

func TestCommitStringParsing(t *testing.T) {
	dataFirstPart := "* DATA:||4e61bacab44e9b4730e44a6615d04098dd3a8eaf|2016-12-20 21:10:41 +0100|Author|user@mail.something|4e61bac|"
	tests := []struct {
		shouldPass    bool
		testName      string
		commitMessage string
	}{
		{true, "normal", "not a fancy message"},
		{true, "extra pipe", "An extra pipe: |"},
		{true, "extra 'Data:'", "DATA: might be trouble"},
	}

	for _, test := range tests {

		t.Run(test.testName, func(t *testing.T) {
			testString := fmt.Sprintf("%s%s", dataFirstPart, test.commitMessage)
			graphItem, err := graphItemFromString(testString, nil)
			if err != nil && test.shouldPass {
				t.Errorf("Could not parse %s", testString)
				return
			}

			if test.commitMessage != graphItem.Subject {
				t.Errorf("%s does not match %s", test.commitMessage, graphItem.Subject)
			}
		})
	}
}