/* * Licensed to the Apache Software Foundation (ASF) under one * or more contributor license agreements. See the NOTICE file * distributed with this work for additional information * regarding copyright ownership. The ASF licenses this file * to you 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 org.apache.isis.core.metamodel.facets.value; import static org.junit.Assert.assertEquals; import static org.junit.Assert.fail; import java.util.Locale; import org.jmock.integration.junit4.JMock; import org.junit.Before; import org.junit.Ignore; import org.junit.Test; import org.junit.runner.RunWith; import org.apache.isis.applib.value.Money; import org.apache.isis.core.metamodel.facetapi.FacetHolder; import org.apache.isis.core.metamodel.facetapi.FacetHolderImpl; import org.apache.isis.core.metamodel.facets.object.parseable.TextEntryParseException; import org.apache.isis.core.metamodel.facets.value.money.MoneyValueSemanticsProvider; @Ignore // TODO once the sematics provide has a way to reset the formatters for the new // local then this test can be reinstated. @RunWith(JMock.class) public class PolishMoneyValueSemanticsProviderTest extends ValueSemanticsProviderAbstractTestCase { private static final String CURRENCY_SPACE = "\u00a0"; private static final String ZLOTYCH_SYMBOL = "\u007a\u0142"; private static final String EURO_SYMBOL = "\u20AC"; private MoneyValueSemanticsProvider adapter; private Money originalMoney; private FacetHolder holder; @Before public void setUpObjects() throws Exception { Locale.setDefault(new Locale("pl", "PL")); originalMoney = new Money(10.50, "pln"); holder = new FacetHolderImpl(); setValue(adapter = new MoneyValueSemanticsProvider(holder, mockServicesInjector)); } private Money createMoney(final double amount, final String currency) { return new Money(amount, currency); } @Test public void testLocale() { assertEquals("PL", Locale.getDefault().getCountry()); assertEquals("pl", Locale.getDefault().getLanguage()); } @Test public void testEncoding() { final String data = adapter.toEncodedString(originalMoney); assertEquals("10.5 PLN", data); } @Test public void testDecoding() { final Object restored = adapter.fromEncodedString("23.77 FFR"); final Money expected = new Money(23.77, "FFR"); assertEquals(expected, restored); } @Test public void testTitleOfWithZlotych() { assertEquals("10,5 " + ZLOTYCH_SYMBOL, adapter.displayTitleOf(originalMoney)); } @Test public void testTitleOfWithNonLocalCurrency() { assertEquals("10,5 USD", adapter.displayTitleOf(createMoney(10.50, "usd"))); } @Test public void testTitleWithUnknownCurrency() { assertEquals("10,5 UNK", adapter.displayTitleOf(createMoney(10.50, "UNK"))); } @Test public void testUserEntryWithCurrency() { final Money money = createMoney(10.5, "gbp"); final Money parsed = adapter.parseTextEntry(money, "22,45 USD"); assertEquals(new Money(22.45, "usd"), parsed); } @Test public void testUserEntryUsesPreviousCurrency() { final Object parsed = adapter.parseTextEntry(originalMoney, "22,45"); assertEquals(new Money(22.45, "pln"), parsed); } @Test public void testReplacementEntryForDefaultCurrency() { final Object parsed = adapter.parseTextEntry(originalMoney, "80,90 " + ZLOTYCH_SYMBOL); assertEquals(new Money(80.90, "pln"), parsed); } @Test public void testSpecifyingCurrencyInEntry() { final Object parsed = adapter.parseTextEntry(originalMoney, "3021,50 cad"); assertEquals("3" + CURRENCY_SPACE + "021,5 CAD", adapter.displayTitleOf(parsed)); } @Test public void testUsingLocalCurrencySymbol() { // MoneyValueSemanticsProvider adapter = new // MoneyValueSemanticsProvider(new Money(0L, "gbp")); final Object parsed = adapter.parseTextEntry(originalMoney, "3021,50 " + ZLOTYCH_SYMBOL); assertEquals("3" + CURRENCY_SPACE + "021,5 " + ZLOTYCH_SYMBOL, adapter.titleString(parsed)); } @Test public void testInvalidCurrencySuffixRejected() throws Exception { final Object parsed = adapter.parseTextEntry(originalMoney, "3" + CURRENCY_SPACE + "021,50 Dm"); assertEquals("3" + CURRENCY_SPACE + "021,5 " + ZLOTYCH_SYMBOL, adapter.titleString(parsed)); } @Test public void testInvalidCurrencySymbolIsRejected() throws Exception { try { adapter.parseTextEntry(originalMoney, EURO_SYMBOL + "3021.50"); fail("invalid code accepted " + adapter); } catch (final TextEntryParseException expected) { } } @Test public void testNewValueDefaultsToLocalCurrency() throws Exception { final Money parsed = adapter.parseTextEntry(originalMoney, "3021,50"); assertEquals("3" + CURRENCY_SPACE + "021,5 " + ZLOTYCH_SYMBOL, adapter.displayTitleOf(parsed)); } @Test public void testUnrelatedCurrencySymbolIsRejected() throws Exception { final Money money = createMoney(1, "eur"); try { adapter.parseTextEntry(money, "$3021.50"); fail("invalid code accepted " + adapter); } catch (final TextEntryParseException expected) { } } }