// Copyright (C) 2016 Opsmate, Inc. // // This Source Code Form is subject to the terms of the Mozilla // Public License, v. 2.0. If a copy of the MPL was not distributed // with this file, You can obtain one at http://mozilla.org/MPL/2.0/. // // This software is distributed WITHOUT A WARRANTY OF ANY KIND. // See the Mozilla Public License for details. package certspotter import ( "testing" "time" ) type timeTest struct { in string ok bool out time.Time } var utcTimeTests = []timeTest{ { "9502101525Z", true, time.Date(1995, time.February, 10, 15, 25, 0, 0, time.UTC) }, { "950210152542Z", true, time.Date(1995, time.February, 10, 15, 25, 42, 0, time.UTC) }, { "1502101525Z", true, time.Date(2015, time.February, 10, 15, 25, 0, 0, time.UTC) }, { "150210152542Z", true, time.Date(2015, time.February, 10, 15, 25, 42, 0, time.UTC) }, { "1502101525+1000", true, time.Date(2015, time.February, 10, 15, 25, 0, 0, time.FixedZone("", 10 * 3600)) }, { "1502101525-1000", true, time.Date(2015, time.February, 10, 15, 25, 0, 0, time.FixedZone("", -1 * (10 * 3600))) }, { "1502101525+1035", true, time.Date(2015, time.February, 10, 15, 25, 0, 0, time.FixedZone("", 10 * 3600 + 35 * 60)) }, { "1502101525-1035", true, time.Date(2015, time.February, 10, 15, 25, 0, 0, time.FixedZone("", -1 * (10 * 3600 + 35 * 60))) }, { "150210152542+1000", true, time.Date(2015, time.February, 10, 15, 25, 42, 0, time.FixedZone("", 10 * 3600)) }, { "150210152542-1000", true, time.Date(2015, time.February, 10, 15, 25, 42, 0, time.FixedZone("", -1 * (10 * 3600))) }, { "150210152542+1035", true, time.Date(2015, time.February, 10, 15, 25, 42, 0, time.FixedZone("", 10 * 3600 + 35 * 60)) }, { "150210152542-1035", true, time.Date(2015, time.February, 10, 15, 25, 42, 0, time.FixedZone("", -1 * (10 * 3600 + 35 * 60))) }, { "1502101525", true, time.Date(2015, time.February, 10, 15, 25, 0, 0, time.UTC) }, { "150210152542", true, time.Date(2015, time.February, 10, 15, 25, 42, 0, time.UTC) }, { "", false, time.Time{} }, { "123", false, time.Time{} }, { "150210152542-10", false, time.Time{} }, { "150210152542F", false, time.Time{} }, { "150210152542ZF", false, time.Time{} }, } func TestUTCTime(t *testing.T) { for i, test := range utcTimeTests { ret, err := parseUTCTime([]byte(test.in)) if err != nil { if test.ok { t.Errorf("#%d: parseUTCTime(%q) failed with error %v", i, test.in, err) } continue } if !test.ok { t.Errorf("#%d: parseUTCTime(%q) succeeded, should have failed", i, test.in) continue } if !test.out.Equal(ret) { t.Errorf("#%d: parseUTCTime(%q) = %v, want %v", i, test.in, ret, test.out) } } } var generalizedTimeTests = []timeTest{ { "2015021015", true, time.Date(2015, time.February, 10, 15, 0, 0, 0, time.UTC) }, { "201502101525", true, time.Date(2015, time.February, 10, 15, 25, 0, 0, time.UTC) }, { "20150210152542", true, time.Date(2015, time.February, 10, 15, 25, 42, 0, time.UTC) }, { "20150210152542.123", true, time.Date(2015, time.February, 10, 15, 25, 42, 123000000, time.UTC) }, { "20150210152542.12", false, time.Time{} }, { "20150210152542.1", false, time.Time{} }, { "20150210152542.", false, time.Time{} }, { "2015021015Z", true, time.Date(2015, time.February, 10, 15, 0, 0, 0, time.UTC) }, { "201502101525Z", true, time.Date(2015, time.February, 10, 15, 25, 0, 0, time.UTC) }, { "20150210152542Z", true, time.Date(2015, time.February, 10, 15, 25, 42, 0, time.UTC) }, { "20150210152542.123Z", true, time.Date(2015, time.February, 10, 15, 25, 42, 123000000, time.UTC) }, { "20150210152542.12Z", false, time.Time{} }, { "20150210152542.1Z", false, time.Time{} }, { "20150210152542.Z", false, time.Time{} }, { "2015021015+1000", true, time.Date(2015, time.February, 10, 15, 0, 0, 0, time.FixedZone("", 10 * 3600)) }, { "201502101525+1000", true, time.Date(2015, time.February, 10, 15, 25, 0, 0, time.FixedZone("", 10 * 3600)) }, { "20150210152542+1000", true, time.Date(2015, time.February, 10, 15, 25, 42, 0, time.FixedZone("", 10 * 3600)) }, { "20150210152542.123+1000", true, time.Date(2015, time.February, 10, 15, 25, 42, 123000000, time.FixedZone("", 10 * 3600)) }, { "20150210152542.12+1000", false, time.Time{} }, { "20150210152542.1+1000", false, time.Time{} }, { "20150210152542.+1000", false, time.Time{} }, { "2015021015-0835", true, time.Date(2015, time.February, 10, 15, 0, 0, 0, time.FixedZone("", -1 * (8 * 3600 + 35 * 60))) }, { "201502101525-0835", true, time.Date(2015, time.February, 10, 15, 25, 0, 0, time.FixedZone("", -1 * (8 * 3600 + 35 * 60))) }, { "20150210152542-0835", true, time.Date(2015, time.February, 10, 15, 25, 42, 0, time.FixedZone("", -1 * (8 * 3600 + 35 * 60))) }, { "20150210152542.123-0835", true, time.Date(2015, time.February, 10, 15, 25, 42, 123000000, time.FixedZone("", -1 * (8 * 3600 + 35 * 60))) }, { "20150210152542.12-0835", false, time.Time{} }, { "20150210152542.1-0835", false, time.Time{} }, { "20150210152542.-0835", false, time.Time{} }, { "", false, time.Time{} }, { "123", false, time.Time{} }, { "2015021015+1000Z", false, time.Time{} }, { "2015021015x", false, time.Time{} }, { "201502101525Zf", false, time.Time{} }, } func TestGeneralizedTime(t *testing.T) { for i, test := range generalizedTimeTests { ret, err := parseGeneralizedTime([]byte(test.in)) if err != nil { if test.ok { t.Errorf("#%d: parseGeneralizedTime(%q) failed with error %v", i, test.in, err) } continue } if !test.ok { t.Errorf("#%d: parseGeneralizedTime(%q) succeeded, should have failed", i, test.in) continue } if !test.out.Equal(ret) { t.Errorf("#%d: parseGeneralizedTime(%q) = %v, want %v", i, test.in, ret, test.out) } } }