1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118
|
// Copyright 2014 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "platform/network/EncodedFormData.h"
#include "testing/gtest/include/gtest/gtest.h"
namespace blink {
namespace {
class EncodedFormDataTest : public ::testing::Test {
public:
void checkDeepCopied(const String& a, const String& b) {
EXPECT_EQ(a, b);
if (b.impl())
EXPECT_NE(a.impl(), b.impl());
}
void checkDeepCopied(const KURL& a, const KURL& b) {
EXPECT_EQ(a, b);
checkDeepCopied(a.getString(), b.getString());
if (a.innerURL() && b.innerURL())
checkDeepCopied(*a.innerURL(), *b.innerURL());
}
void checkDeepCopied(const FormDataElement& a, const FormDataElement& b) {
EXPECT_EQ(a, b);
checkDeepCopied(a.m_filename, b.m_filename);
checkDeepCopied(a.m_blobUUID, b.m_blobUUID);
checkDeepCopied(a.m_fileSystemURL, b.m_fileSystemURL);
}
};
TEST_F(EncodedFormDataTest, DeepCopy) {
RefPtr<EncodedFormData> original(EncodedFormData::create());
original->appendData("Foo", 3);
original->appendFileRange("example.txt", 12345, 56789, 9999.0);
original->appendBlob("originalUUID", nullptr);
original->appendFileSystemURLRange(KURL(KURL(), "ws://localhost/"), 23456,
34567, 1111.0);
Vector<char> boundaryVector;
boundaryVector.append("----boundaryForTest", 19);
original->setIdentifier(45678);
original->setBoundary(boundaryVector);
original->setContainsPasswordData(true);
RefPtr<EncodedFormData> copy = original->deepCopy();
// Check that contents are copied (compare the copy with expected values).
const Vector<FormDataElement>& originalElements = original->elements();
const Vector<FormDataElement>& copyElements = copy->elements();
ASSERT_EQ(4ul, copyElements.size());
Vector<char> fooVector;
fooVector.append("Foo", 3);
EXPECT_EQ(FormDataElement::data, copyElements[0].m_type);
EXPECT_EQ(fooVector, copyElements[0].m_data);
EXPECT_EQ(FormDataElement::encodedFile, copyElements[1].m_type);
EXPECT_EQ(String("example.txt"), copyElements[1].m_filename);
EXPECT_EQ(12345ll, copyElements[1].m_fileStart);
EXPECT_EQ(56789ll, copyElements[1].m_fileLength);
EXPECT_EQ(9999.0, copyElements[1].m_expectedFileModificationTime);
EXPECT_EQ(FormDataElement::encodedBlob, copyElements[2].m_type);
EXPECT_EQ(String("originalUUID"), copyElements[2].m_blobUUID);
EXPECT_EQ(FormDataElement::encodedFileSystemURL, copyElements[3].m_type);
EXPECT_EQ(KURL(KURL(), String("ws://localhost/")),
copyElements[3].m_fileSystemURL);
EXPECT_EQ(23456ll, copyElements[3].m_fileStart);
EXPECT_EQ(34567ll, copyElements[3].m_fileLength);
EXPECT_EQ(1111.0, copyElements[3].m_expectedFileModificationTime);
EXPECT_EQ(45678, copy->identifier());
EXPECT_EQ(boundaryVector, copy->boundary());
EXPECT_EQ(true, copy->containsPasswordData());
// Check that contents are copied (compare the copy with the original).
EXPECT_EQ(*original, *copy);
// Check pointers are different, i.e. deep-copied.
ASSERT_NE(original.get(), copy.get());
for (size_t i = 0; i < 4; ++i) {
if (copyElements[i].m_filename.impl()) {
EXPECT_NE(originalElements[i].m_filename.impl(),
copyElements[i].m_filename.impl());
EXPECT_TRUE(copyElements[i].m_filename.impl()->hasOneRef());
}
if (copyElements[i].m_blobUUID.impl()) {
EXPECT_NE(originalElements[i].m_blobUUID.impl(),
copyElements[i].m_blobUUID.impl());
EXPECT_TRUE(copyElements[i].m_blobUUID.impl()->hasOneRef());
}
if (copyElements[i].m_fileSystemURL.getString().impl()) {
EXPECT_NE(originalElements[i].m_fileSystemURL.getString().impl(),
copyElements[i].m_fileSystemURL.getString().impl());
EXPECT_TRUE(
copyElements[i].m_fileSystemURL.getString().impl()->hasOneRef());
}
EXPECT_EQ(nullptr, copyElements[i].m_fileSystemURL.innerURL());
// m_optionalBlobDataHandle is not checked, because BlobDataHandle is
// ThreadSafeRefCounted.
}
}
} // namespace
} // namespace blink
|