View Javadoc
1   /*
2    * Copyright (c) 2012-2023, jcabi.com
3    * All rights reserved.
4    *
5    * Redistribution and use in source and binary forms, with or without
6    * modification, are permitted provided that the following conditions
7    * are met: 1) Redistributions of source code must retain the above
8    * copyright notice, this list of conditions and the following
9    * disclaimer. 2) Redistributions in binary form must reproduce the above
10   * copyright notice, this list of conditions and the following
11   * disclaimer in the documentation and/or other materials provided
12   * with the distribution. 3) Neither the name of the jcabi.com nor
13   * the names of its contributors may be used to endorse or promote
14   * products derived from this software without specific prior written
15   * permission.
16   *
17   * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
18   * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT
19   * NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
20   * FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL
21   * THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT,
22   * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
23   * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
24   * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
25   * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
26   * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
27   * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
28   * OF THE POSSIBILITY OF SUCH DAMAGE.
29   */
30  package com.jcabi.log;
31  
32  import java.util.Arrays;
33  import java.util.Collection;
34  import java.util.FormattableFlags;
35  import java.util.Locale;
36  import org.hamcrest.MatcherAssert;
37  import org.hamcrest.Matchers;
38  import org.junit.jupiter.api.Test;
39  import org.junit.jupiter.params.ParameterizedTest;
40  import org.junit.jupiter.params.provider.MethodSource;
41  
42  /**
43   * Test case for {@link MsDecor}.
44   *
45   * @since 0.1
46   * @checkstyle ParameterNumberCheck (500 lines)
47   */
48  final class MsDecorTest {
49  
50      @ParameterizedTest
51      @MethodSource("params")
52      void testPrintsRight(final long value, final String text,
53          final int flags, final int width, final int precision) {
54          Locale.setDefault(Locale.US);
55          MatcherAssert.assertThat(
56              new Printed(new MsDecor(value), flags, width, precision),
57              Matchers.hasToString(text)
58          );
59      }
60  
61      @ParameterizedTest
62      @MethodSource("params")
63      void testLogsRight(final long value, final String text,
64          final int flags, final int width, final int precision) {
65          Locale.setDefault(Locale.US);
66          MatcherAssert.assertThat(
67              new Logged(new MsDecor(value), flags, width, precision),
68              Matchers.hasToString(text)
69          );
70      }
71  
72      @Test
73      void testPrintsNullRight() {
74          MatcherAssert.assertThat(
75              new Logged(new MsDecor(null), 0, 0, 0),
76              Matchers.hasToString("NULL")
77          );
78      }
79  
80      /**
81       * Params for this parametrized test.
82       * @return Array of arrays of params for ctor
83       */
84      @SuppressWarnings("PMD.UnusedPrivateMethod")
85      private static Collection<Object[]> params() {
86          return Arrays.asList(
87              new Object[][] {
88                  // @checkstyle LineLength (20 lines)
89                  // @checkstyle MagicNumber (20 lines)
90                  {13L, "13ms", 0, 0, -1},
91                  {13L, "13.0ms", 0, 0, 1},
92                  {1024L, "1s", 0, 0, 0},
93                  {6001L, "6.0010s", 0, 0, 4},
94                  {122_001L, "  2MIN", FormattableFlags.UPPERCASE, 6, 0},
95                  {3_789_003L, "1hr", 0, 0, 0},
96                  {86_400_000L, "1days", 0, 0, 0},
97                  {864_000_000L, "10days", 0, 0, 0},
98              }
99          );
100     }
101 }