2015-12-10 17:19:38 -05:00
|
|
|
// Copyright 2015 The Hugo Authors. All rights reserved.
|
|
|
|
//
|
|
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
// you may not use this file except in compliance with the License.
|
|
|
|
// You may obtain a copy of the License at
|
|
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
//
|
|
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
// See the License for the specific language governing permissions and
|
|
|
|
// limitations under the License.
|
|
|
|
|
2015-03-15 18:32:41 -04:00
|
|
|
package commands
|
|
|
|
|
|
|
|
// TODO Support Mac Encoding (\r)
|
|
|
|
|
|
|
|
import (
|
|
|
|
"bytes"
|
|
|
|
"strings"
|
|
|
|
"testing"
|
|
|
|
"time"
|
|
|
|
|
|
|
|
"github.com/spf13/hugo/parser"
|
|
|
|
)
|
|
|
|
|
|
|
|
var (
|
|
|
|
jsonFM = "{\n \"date\": \"12-04-06\",\n \"title\": \"test json\"\n}"
|
|
|
|
jsonDraftFM = "{\n \"draft\": true,\n \"date\": \"12-04-06\",\n \"title\":\"test json\"\n}"
|
|
|
|
tomlFM = "+++\n date= \"12-04-06\"\n title= \"test toml\"\n+++"
|
|
|
|
tomlDraftFM = "+++\n draft= true\n date= \"12-04-06\"\n title=\"test toml\"\n+++"
|
|
|
|
yamlFM = "---\n date: \"12-04-06\"\n title: \"test yaml\"\n---"
|
|
|
|
yamlDraftFM = "---\n draft: true\n date: \"12-04-06\"\n title: \"test yaml\"\n---"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestUndraftContent(t *testing.T) {
|
|
|
|
tests := []struct {
|
|
|
|
fm string
|
|
|
|
expectedErr string
|
|
|
|
}{
|
|
|
|
{jsonFM, "not a Draft: nothing was done"},
|
|
|
|
{jsonDraftFM, ""},
|
|
|
|
{tomlFM, "not a Draft: nothing was done"},
|
|
|
|
{tomlDraftFM, ""},
|
|
|
|
{yamlFM, "not a Draft: nothing was done"},
|
|
|
|
{yamlDraftFM, ""},
|
|
|
|
}
|
|
|
|
|
2016-12-26 16:23:20 -05:00
|
|
|
for i, test := range tests {
|
2015-03-15 18:32:41 -04:00
|
|
|
r := bytes.NewReader([]byte(test.fm))
|
|
|
|
p, _ := parser.ReadFrom(r)
|
|
|
|
res, err := undraftContent(p)
|
|
|
|
if test.expectedErr != "" {
|
|
|
|
if err == nil {
|
2017-03-11 13:07:32 -05:00
|
|
|
t.Errorf("[%d] Expected error, got none", i)
|
2015-03-15 18:32:41 -04:00
|
|
|
continue
|
|
|
|
}
|
|
|
|
if err.Error() != test.expectedErr {
|
2016-12-26 16:23:20 -05:00
|
|
|
t.Errorf("[%d] Expected %q, got %q", i, test.expectedErr, err)
|
2015-03-15 18:32:41 -04:00
|
|
|
continue
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
r = bytes.NewReader(res.Bytes())
|
|
|
|
p, _ = parser.ReadFrom(r)
|
|
|
|
meta, err := p.Metadata()
|
|
|
|
if err != nil {
|
2016-12-26 16:23:20 -05:00
|
|
|
t.Errorf("[%d] unexpected error %q", i, err)
|
2015-03-15 18:32:41 -04:00
|
|
|
continue
|
|
|
|
}
|
|
|
|
for k, v := range meta.(map[string]interface{}) {
|
|
|
|
if k == "draft" {
|
|
|
|
if v.(bool) {
|
2016-12-26 16:23:20 -05:00
|
|
|
t.Errorf("[%d] Expected %q to be \"false\", got \"true\"", i, k)
|
2015-03-15 18:32:41 -04:00
|
|
|
continue
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if k == "date" {
|
|
|
|
if !strings.HasPrefix(v.(string), time.Now().Format("2006-01-02")) {
|
2016-12-26 16:23:20 -05:00
|
|
|
t.Errorf("[%d] Expected %v to start with %v", i, v.(string), time.Now().Format("2006-01-02"))
|
2015-03-15 18:32:41 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|