/*
* 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 com.facebook.presto.type;
import com.facebook.presto.operator.scalar.AbstractTestFunctions;
import org.testng.annotations.Test;
public class TestDecimalParametricType
extends AbstractTestFunctions
{
@Test
public void decimalIsCreatedWithPrecisionAndScaleDefined()
{
assertDecimalFunction("CAST(1 AS DECIMAL(2, 0))", decimal("01"));
assertDecimalFunction("CAST(0.01 AS DECIMAL(2, 2))", decimal(".01"));
assertDecimalFunction("CAST(0.02 AS DECIMAL(10, 10))", decimal(".0200000000"));
assertDecimalFunction("CAST(0.02 AS DECIMAL(10, 8))", decimal("00.02000000"));
}
@Test
public void decimalIsCreatedWithOnlyPrecisionDefined()
{
assertDecimalFunction("CAST(1 AS DECIMAL(2))", decimal("01"));
assertDecimalFunction("CAST(-22 AS DECIMAL(3))", decimal("-022"));
assertDecimalFunction("CAST(31.41 AS DECIMAL(4))", decimal("0031"));
}
@Test
public void decimalIsCreatedWithoutParameters()
{
assertDecimalFunction("CAST(1 AS DECIMAL)", maxPrecisionDecimal(1));
assertDecimalFunction("CAST(-22 AS DECIMAL)", maxPrecisionDecimal(-22));
assertDecimalFunction("CAST(31.41 AS DECIMAL)", maxPrecisionDecimal(31));
}
@Test
public void creatingDecimalRoundsValueProperly()
{
assertDecimalFunction("CAST(0.022 AS DECIMAL(4, 2))", decimal("00.02"));
assertDecimalFunction("CAST(0.025 AS DECIMAL(4, 2))", decimal("00.03"));
assertDecimalFunction("CAST(32.01 AS DECIMAL(3, 1))", decimal("32.0"));
assertDecimalFunction("CAST(32.06 AS DECIMAL(3, 1))", decimal("32.1"));
assertDecimalFunction("CAST(32.1 AS DECIMAL(3, 0))", decimal("032"));
assertDecimalFunction("CAST(32.5 AS DECIMAL(3, 0))", decimal("033"));
assertDecimalFunction("CAST(-0.022 AS DECIMAL(4, 2))", decimal("-00.02"));
assertDecimalFunction("CAST(-0.025 AS DECIMAL(4, 2))", decimal("-00.03"));
}
@Test
public void decimalIsNotCreatedWhenScaleExceedsPrecision()
{
assertInvalidFunction("CAST(1 AS DECIMAL(1,2))", "DECIMAL scale must be in range [0, precision]");
assertInvalidFunction("CAST(-22 AS DECIMAL(20,21))", "DECIMAL scale must be in range [0, precision]");
assertInvalidFunction("CAST(31.41 AS DECIMAL(0,1))", "DECIMAL precision must be in range [1, 38]");
}
@Test
public void decimalWithZeroLengthCannotBeCreated()
{
assertInvalidFunction("CAST(1 AS DECIMAL(0,0))", "DECIMAL precision must be in range [1, 38]");
assertInvalidFunction("CAST(0 AS DECIMAL(0,0))", "DECIMAL precision must be in range [1, 38]");
assertInvalidFunction("CAST(1 AS DECIMAL(0))", "DECIMAL precision must be in range [1, 38]");
assertInvalidFunction("CAST(0 AS DECIMAL(0))", "DECIMAL precision must be in range [1, 38]");
}
}