github.com/SuCicada/su-hugo@v1.0.0/parser/pageparser/pageparser_main_test.go (about)

     1  // Copyright 2018 The Hugo Authors. All rights reserved.
     2  //
     3  // Licensed under the Apache License, Version 2.0 (the "License");
     4  // you may not use this file except in compliance with the License.
     5  // You may obtain a copy of the License at
     6  // http://www.apache.org/licenses/LICENSE-2.0
     7  //
     8  // Unless required by applicable law or agreed to in writing, software
     9  // distributed under the License is distributed on an "AS IS" BASIS,
    10  // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
    11  // See the License for the specific language governing permissions and
    12  // limitations under the License.
    13  
    14  package pageparser
    15  
    16  import (
    17  	"testing"
    18  
    19  	qt "github.com/frankban/quicktest"
    20  )
    21  
    22  func TestMain(t *testing.T) {
    23  	t.Parallel()
    24  	c := qt.New(t)
    25  
    26  	mainTests := []lexerTest{
    27  		{"emoji #1", "Some text with :emoji:", []typeText{nti(tText, "Some text with "), nti(TypeEmoji, ":emoji:"), tstEOF}},
    28  		{"emoji #2", "Some text with :emoji: and some text.", []typeText{nti(tText, "Some text with "), nti(TypeEmoji, ":emoji:"), nti(tText, " and some text."), tstEOF}},
    29  		{"looks like an emoji #1", "Some text and then :emoji", []typeText{nti(tText, "Some text and then "), nti(tText, ":"), nti(tText, "emoji"), tstEOF}},
    30  		{"looks like an emoji #2", "Some text and then ::", []typeText{nti(tText, "Some text and then "), nti(tText, ":"), nti(tText, ":"), tstEOF}},
    31  		{"looks like an emoji #3", ":Some :text", []typeText{nti(tText, ":"), nti(tText, "Some "), nti(tText, ":"), nti(tText, "text"), tstEOF}},
    32  	}
    33  
    34  	for i, test := range mainTests {
    35  		items := collectWithConfig([]byte(test.input), false, lexMainSection, Config{EnableEmoji: true})
    36  		if !equal(test.input, items, test.items) {
    37  			got := itemsToString(items, []byte(test.input))
    38  			expected := testItemsToString(test.items)
    39  			c.Assert(got, qt.Equals, expected, qt.Commentf("Test %d: %s", i, test.name))
    40  		}
    41  	}
    42  }