xref: /llvm-project/flang/unittests/Runtime/LogicalFormatTest.cpp (revision eb77f442b342a1bb234254e05759933bad9dfab1)
1ffc67bb3SDavid Spickett //===-- flang/unittests/Runtime/LogicalFormatTest.cpp -----------*- C++ -*-===//
2ffc67bb3SDavid Spickett //
3ffc67bb3SDavid Spickett // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4ffc67bb3SDavid Spickett // See https://llvm.org/LICENSE.txt for license information.
5ffc67bb3SDavid Spickett // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6ffc67bb3SDavid Spickett //
7ffc67bb3SDavid Spickett //===----------------------------------------------------------------------===//
8ffc67bb3SDavid Spickett 
9ffc67bb3SDavid Spickett #include "CrashHandlerFixture.h"
10ffc67bb3SDavid Spickett #include "flang/Runtime/descriptor.h"
11c91ba043SMichael Kruse #include "flang/Runtime/io-api-consts.h"
12ffc67bb3SDavid Spickett #include <algorithm>
13ffc67bb3SDavid Spickett #include <array>
14ffc67bb3SDavid Spickett #include <cstring>
15ffc67bb3SDavid Spickett #include <gtest/gtest.h>
16ffc67bb3SDavid Spickett #include <tuple>
17ffc67bb3SDavid Spickett 
18ffc67bb3SDavid Spickett using namespace Fortran::runtime;
19ffc67bb3SDavid Spickett using namespace Fortran::runtime::io;
20ffc67bb3SDavid Spickett 
21ffc67bb3SDavid Spickett TEST(IOApiTests, LogicalFormatTest) {
22ffc67bb3SDavid Spickett   static constexpr int bufferSize{29};
23ffc67bb3SDavid Spickett   char buffer[bufferSize];
24ffc67bb3SDavid Spickett 
25ffc67bb3SDavid Spickett   // Create format for all types and values to be written
26*eb77f442SPeter Klausler   const char *format{"(L0,L3,I3,L2,L2,I3,L2,A3,L2,L,F4.1,L2)"};
27ffc67bb3SDavid Spickett   auto cookie{IONAME(BeginInternalFormattedOutput)(
28ffc67bb3SDavid Spickett       buffer, bufferSize, format, std::strlen(format))};
29ffc67bb3SDavid Spickett 
30ffc67bb3SDavid Spickett   // Write string, integer, and logical values to buffer
31ffc67bb3SDavid Spickett   IONAME(OutputLogical)(cookie, true);
32ffc67bb3SDavid Spickett   IONAME(OutputLogical)(cookie, false);
33ffc67bb3SDavid Spickett   IONAME(OutputInteger64)(cookie, 6);
34ffc67bb3SDavid Spickett   IONAME(OutputInteger32)(cookie, 22);
35ffc67bb3SDavid Spickett   IONAME(OutputInteger32)(cookie, 0);
36ffc67bb3SDavid Spickett   IONAME(OutputInteger32)(cookie, -2);
37ffc67bb3SDavid Spickett   IONAME(OutputCharacter)(cookie, "ABC", 3);
38ffc67bb3SDavid Spickett   IONAME(OutputCharacter)(cookie, "AB", 2);
39ffc67bb3SDavid Spickett   IONAME(OutputReal64)(cookie, 0.0);
40ffc67bb3SDavid Spickett   IONAME(OutputCharacter)(cookie, "", 0);
41ffc67bb3SDavid Spickett   IONAME(OutputReal32)(cookie, 2.3);
42ffc67bb3SDavid Spickett   IONAME(OutputReal32)(cookie, 2.3);
43ffc67bb3SDavid Spickett 
44ffc67bb3SDavid Spickett   // Ensure IO succeeded
45ffc67bb3SDavid Spickett   auto status{IONAME(EndIoStatement)(cookie)};
46ffc67bb3SDavid Spickett   ASSERT_EQ(status, 0) << "logical format: '" << format << "' failed, status "
47ffc67bb3SDavid Spickett                        << static_cast<int>(status);
48ffc67bb3SDavid Spickett 
49ffc67bb3SDavid Spickett   // Ensure final buffer matches expected string output
50ffc67bb3SDavid Spickett   static const std::string expect{"T  F  6 T F -2 T AB FF 2.3 T"};
51ffc67bb3SDavid Spickett 
52ffc67bb3SDavid Spickett   // expect.size() == bufferSize - 1
53ffc67bb3SDavid Spickett   std::string bufferStr = std::string(buffer, bufferSize - 1);
54ffc67bb3SDavid Spickett   ASSERT_TRUE(expect == bufferStr)
55ffc67bb3SDavid Spickett       << "Expected '" << expect << "', got '" << bufferStr << "'";
56ffc67bb3SDavid Spickett }
57