// Copyright (c) 2023 IBM Corp. // 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. package di import ( "testing" A "github.com/IBM/fp-go/array" E "github.com/IBM/fp-go/either" F "github.com/IBM/fp-go/function" IOE "github.com/IBM/fp-go/ioeither" O "github.com/IBM/fp-go/option" "github.com/stretchr/testify/assert" ) var ( toInt = toType[int]() toString = toType[string]() ) func TestToType(t *testing.T) { // good cases assert.Equal(t, E.Of[error](10), toInt(any(10))) assert.Equal(t, E.Of[error]("Carsten"), toString(any("Carsten"))) assert.Equal(t, E.Of[error](O.Of("Carsten")), toType[O.Option[string]]()(any(O.Of("Carsten")))) assert.Equal(t, E.Of[error](O.Of(any("Carsten"))), toType[O.Option[any]]()(any(O.Of(any("Carsten"))))) // failure assert.False(t, E.IsRight(toInt(any("Carsten")))) assert.False(t, E.IsRight(toType[O.Option[string]]()(O.Of(any("Carsten"))))) } func TestToOptionType(t *testing.T) { // shortcuts toOptInt := toOptionType(toInt) toOptString := toOptionType(toString) // good cases assert.Equal(t, E.Of[error](O.Of(10)), toOptInt(any(O.Of(any(10))))) assert.Equal(t, E.Of[error](O.Of("Carsten")), toOptString(any(O.Of(any("Carsten"))))) // bad cases assert.False(t, E.IsRight(toOptInt(any(10)))) assert.False(t, E.IsRight(toOptInt(any(O.Of(10))))) } func invokeIOEither[T any](e E.Either[error, IOE.IOEither[error, T]]) E.Either[error, T] { return F.Pipe1( e, E.Chain(func(ioe IOE.IOEither[error, T]) E.Either[error, T] { return ioe() }), ) } func TestToIOEitherType(t *testing.T) { // shortcuts toIOEitherInt := toIOEitherType(toInt) toIOEitherString := toIOEitherType(toString) // good cases assert.Equal(t, E.Of[error](10), invokeIOEither(toIOEitherInt(any(IOE.Of[error](any(10)))))) assert.Equal(t, E.Of[error]("Carsten"), invokeIOEither(toIOEitherString(any(IOE.Of[error](any("Carsten")))))) // bad cases assert.False(t, E.IsRight(invokeIOEither(toIOEitherString(any(IOE.Of[error](any(10))))))) assert.False(t, E.IsRight(invokeIOEither(toIOEitherString(any(IOE.Of[error]("Carsten")))))) assert.False(t, E.IsRight(invokeIOEither(toIOEitherString(any("Carsten"))))) } func TestToArrayType(t *testing.T) { // shortcuts toArrayString := toArrayType(toString) // good cases assert.Equal(t, E.Of[error](A.From("a", "b")), toArrayString(any(A.From(any("a"), any("b"))))) }