void test_trace_check_compares() {
trace("test layer") << "foo" << end();
CHECK_TRACE_CONTENTS("test layer: foo");
}
void test_trace_check_ignores_other_layers() {
trace("test layer 1") << "foo" << end();
trace("test layer 2") << "bar" << end();
CHECK_TRACE_CONTENTS("test layer 1: foo");
CHECK_TRACE_DOESNT_CONTAIN("test layer 2: foo");
}
void test_trace_check_ignores_leading_whitespace() {
trace("test layer 1") << " foo" << end();
CHECK(trace_count("test layer 1", "foo") == 1);
CHECK(trace_count("test layer 1", " foo") == 1);
}
void test_trace_check_ignores_other_lines() {
trace("test layer 1") << "foo" << end();
trace("test layer 1") << "bar" << end();
CHECK_TRACE_CONTENTS("test layer 1: foo");
}
void test_trace_check_ignores_other_lines2() {
trace("test layer 1") << "foo" << end();
trace("test layer 1") << "bar" << end();
CHECK_TRACE_CONTENTS("test layer 1: bar");
}
void test_trace_ignores_trailing_whitespace() {
trace("test layer 1") << "foo\n" << end();
CHECK_TRACE_CONTENTS("test layer 1: foo");
}
void test_trace_ignores_trailing_whitespace2() {
trace("test layer 1") << "foo " << end();
CHECK_TRACE_CONTENTS("test layer 1: foo");
}
void test_trace_orders_across_layers() {
trace("test layer 1") << "foo" << end();
trace("test layer 2") << "bar" << end();
trace("test layer 1") << "qux" << end();
CHECK_TRACE_CONTENTS("test layer 1: foo^Dtest layer 2: bar^Dtest layer 1: qux^D");
}
void test_trace_supports_count() {
trace("test layer 1") << "foo" << end();
trace("test layer 1") << "foo" << end();
CHECK_EQ(trace_count("test layer 1", "foo"), 2);
}
void test_trace_supports_count2() {
trace("test layer 1") << "foo" << end();
trace("test layer 1") << "bar" << end();
CHECK_EQ(trace_count("test layer 1"), 2);
}
void test_trace_count_ignores_trailing_whitespace() {
trace("test layer 1") << "foo\n" << end();
CHECK(trace_count("test layer 1", "foo") == 1);
}
^L
void test_split_returns_at_least_one_elem() {
vector<string> result = split("", ",");
CHECK_EQ(result.size(), 1);
CHECK_EQ(result.at(0), "");
}
void test_split_returns_entire_input_when_no_delim() {
vector<string> result = split("abc"// Copyright (c) 2020, Andinus <andinus@inventati.org>
// Permission to use, copy, modify, and/or distribute this software for any
// purpose with or without fee is hereby granted, provided that the above
// copyright notice and this permission notice appear in all copies.
// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
package bing
import (
"encoding/json"
"fmt"
"io/ioutil"
"net/http"
"time"
)
// Photo holds responses
type Photo struct {
StartDate string `json:"startdate"`
FullStartDate string `json:"fullstartdate"`
EndDate string `json:"enddate"`
URL string `json:"url"`
URLBase string `json:"urlbase"`
Copyright string `json:"copyright"`
CopyrightLink string `json:"copyrightlink"`
Title string `json:"title"`
Hsh string `json:"hsh"`
}
// BPOD holds list of response
type BPOD struct {
Photos []Photo `json:"images"`
}
// BPODPath returns Bing Photo of the Day responses
func BPODPath(bpodInfo map[string]string, timeout time.Duration) (BPOD, error) {
var err error
bpodRes := BPOD{}
client := http.Client{
Timeout: time.Second * timeout,
}
req, err := http.NewRequest(http.MethodGet, bpodInfo["api"], nil)
if err != nil {
return bpodRes, err
}
q := req.URL.Query()
q.Add("format", "js")