blob: 062163e02f430847d49f9cd64969172664aa383e [file] [log] [blame]
// Copyright ©2020 The Gonum Authors. All rights reserved.
// Use of this code is governed by a BSD-style
// license that can be found in the LICENSE file
package cscalar
import (
"math"
"math/cmplx"
"testing"
)
var parseTests = []struct {
s string
want complex128
wantErr error
}{
// Simple error states:
{s: "", wantErr: parseError{state: -1}},
{s: "()", wantErr: parseError{string: "()", state: -1}},
{s: "(1", wantErr: parseError{string: "(1", state: -1}},
{s: "1)", wantErr: parseError{string: "1)", state: -1}},
// Ambiguous parse error states:
{s: "1+2i+3i", wantErr: parseError{string: "1+2i+3i", state: -1}},
{s: "1e-4i+", wantErr: parseError{string: "1e-4i+", state: -1}},
{s: "1e-4i-", wantErr: parseError{string: "1e-4i-", state: -1}},
// Valid input:
{s: "1+4i", want: 1 + 4i},
{s: "4i+1", want: 1 + 4i},
{s: "+1+4i", want: 1 + 4i},
{s: "+4i+1", want: 1 + 4i},
{s: ".1+.4i", want: 0.1 + 0.4i},
{s: ".4i+.1", want: 0.1 + 0.4i},
{s: "+.1+.4i", want: 0.1 + 0.4i},
{s: "+.4i+.1", want: 0.1 + 0.4i},
{s: "1.+4.i", want: 1 + 4i},
{s: "4.i+1.", want: 1 + 4i},
{s: "+1.+4.i", want: 1 + 4i},
{s: "+4.i+1.", want: 1 + 4i},
{s: "1.0+4.0i", want: 1 + 4i},
{s: "4.0i+1.0", want: 1 + 4i},
{s: "+1.0+4.0i", want: 1 + 4i},
{s: "+4.0i+1.0", want: 1 + 4i},
{s: "1.0e-4+1i", want: 1e-4 + 1i},
{s: "1.0e-4+i", want: 1e-4 + 1i},
{s: "1.0e-4-i", want: 1e-4 - 1i},
{s: "1.0e-4i-1", want: -1 + 1e-4i},
{s: "1.0e-4i+1", want: 1 + 1e-4i},
{s: "1e-4+1i", want: 1e-4 + 1i},
{s: "1e-4+i", want: 1e-4 + 1i},
{s: "1e-4-i", want: 1e-4 - 1i},
{s: "1e-4i-1", want: -1 + 1e-4i},
{s: "1e-4i+1", want: 1 + 1e-4i},
{s: "(1+4i)", want: 1 + 4i},
{s: "(4i+1)", want: 1 + 4i},
{s: "(+1+4i)", want: 1 + 4i},
{s: "(+4i+1)", want: 1 + 4i},
{s: "(1e-4+1i)", want: 1e-4 + 1i},
{s: "(1e-4+i)", want: 1e-4 + 1i},
{s: "(1e-4-i)", want: 1e-4 - 1i},
{s: "(1e-4i-1)", want: -1 + 1e-4i},
{s: "(1e-4i+1)", want: 1 + 1e-4i},
{s: "NaN", want: cmplx.NaN()},
{s: "nan", want: cmplx.NaN()},
{s: "Inf", want: cmplx.Inf()},
{s: "inf", want: cmplx.Inf()},
{s: "(Inf+Infi)", want: complex(math.Inf(1), math.Inf(1))},
{s: "(-Inf+Infi)", want: complex(math.Inf(-1), math.Inf(1))},
{s: "(+Inf-Infi)", want: complex(math.Inf(1), math.Inf(-1))},
{s: "(inf+infi)", want: complex(math.Inf(1), math.Inf(1))},
{s: "(-inf+infi)", want: complex(math.Inf(-1), math.Inf(1))},
{s: "(+inf-infi)", want: complex(math.Inf(1), math.Inf(-1))},
{s: "(nan+nani)", want: complex(math.NaN(), math.NaN())},
{s: "(nan-nani)", want: complex(math.NaN(), math.NaN())},
}
func TestParse(t *testing.T) {
for _, test := range parseTests {
got, err := parse(test.s)
if err != test.wantErr {
t.Errorf("unexpected error for Parse(%q): got:%#v, want:%#v", test.s, err, test.wantErr)
}
if err != nil {
continue
}
if !Same(got, test.want) {
t.Errorf("unexpected result for Parse(%q): got:%v, want:%v", test.s, got, test.want)
}
}
}