[Support] Allow discarding a FileOutputBuffer without removing the memory mapping
[llvm-complete.git] / unittests / ObjectYAML / YAMLTest.cpp
blob606e160d19a5be12e432b5f00fbb67d17934d882
1 //===- YAMLTest.cpp - Tests for Object YAML -------------------------------===//
2 //
3 // The LLVM Compiler Infrastructure
4 //
5 // This file is distributed under the University of Illinois Open Source
6 // License. See LICENSE.TXT for details.
7 //
8 //===----------------------------------------------------------------------===//
10 #include "llvm/ObjectYAML/YAML.h"
11 #include "llvm/Support/YAMLTraits.h"
12 #include "gtest/gtest.h"
14 using namespace llvm;
16 struct BinaryHolder {
17 yaml::BinaryRef Binary;
20 namespace llvm {
21 namespace yaml {
22 template <>
23 struct MappingTraits<BinaryHolder> {
24 static void mapping(IO &IO, BinaryHolder &BH) {
25 IO.mapRequired("Binary", BH.Binary);
28 } // end namespace yaml
29 } // end namespace llvm
31 TEST(ObjectYAML, BinaryRef) {
32 BinaryHolder BH;
33 SmallVector<char, 32> Buf;
34 llvm::raw_svector_ostream OS(Buf);
35 yaml::Output YOut(OS);
36 YOut << BH;
37 EXPECT_NE(OS.str().find("''"), StringRef::npos);