* Add streaming load feature. You can execute 'help stream load;' to see more information. Changed: * Loading phase of a certain table can be parallelized, to reduce the load job execution time when multi load jobs to a single table. * Using RocksDB to save the header info of tablets in Backends, to reduce the IO operations and increate speeding of restarting. Fixed: * A lot of bugs fixed.
62 lines
1.6 KiB
C++
62 lines
1.6 KiB
C++
// Copyright (c) 2017, Baidu.com, Inc. All Rights Reserved
|
|
|
|
// Licensed 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.
|
|
|
|
#include "http/message_body_sink.h"
|
|
|
|
#include <gtest/gtest.h>
|
|
|
|
#include <stdio.h>
|
|
#include <sys/types.h>
|
|
#include <sys/stat.h>
|
|
#include <fcntl.h>
|
|
|
|
namespace palo {
|
|
|
|
class MessageBodySinkTest : public testing::Test {
|
|
public:
|
|
MessageBodySinkTest() { }
|
|
virtual ~MessageBodySinkTest() { }
|
|
|
|
void SetUp() override {
|
|
}
|
|
private:
|
|
};
|
|
|
|
TEST_F(MessageBodySinkTest, file_sink) {
|
|
char data[] = "hello world";
|
|
|
|
MessageBodyFileSink sink("./body_sink_test_file_sink");
|
|
ASSERT_TRUE(sink.open().ok());
|
|
ASSERT_TRUE(sink.append(data, sizeof(data)).ok());
|
|
ASSERT_TRUE(sink.finish().ok());
|
|
|
|
{
|
|
char buf[256];
|
|
memset(buf, 0, 256);
|
|
int fd = open("././body_sink_test_file_sink", O_RDONLY);
|
|
read(fd, buf, 256);
|
|
close(fd);
|
|
ASSERT_STREQ("hello world", buf);
|
|
unlink("././body_sink_test_file_sink");
|
|
}
|
|
}
|
|
|
|
}
|
|
|
|
int main(int argc, char* argv[]) {
|
|
::testing::InitGoogleTest(&argc, argv);
|
|
return RUN_ALL_TESTS();
|
|
}
|