From 4b8b8397d1e5ec0ee9465d3f92019c53095adb78 Mon Sep 17 00:00:00 2001
From: chengdu <3281328128@qq.com>
Date: Sat, 13 Jul 2019 15:49:36 +0800
Subject: [PATCH] add fdfs upload download test
---
pom.xml | 15 +++
.../java/org/csource/fastdfs/FdfsTest.java | 99 +++++++++++++++++++
src/test/resources/fdfs_client.conf | 3 +-
src/test/resources/log4j.properties | 12 +++
4 files changed, 128 insertions(+), 1 deletion(-)
create mode 100644 src/test/java/org/csource/fastdfs/FdfsTest.java
create mode 100644 src/test/resources/log4j.properties
diff --git a/pom.xml b/pom.xml
index 1297337..7485dc4 100644
--- a/pom.xml
+++ b/pom.xml
@@ -17,6 +17,21 @@
1.6
+
+
+
+ org.slf4j
+ slf4j-log4j12
+ 1.7.26
+
+
+ junit
+ junit
+ 4.12
+ test
+
+
+
diff --git a/src/test/java/org/csource/fastdfs/FdfsTest.java b/src/test/java/org/csource/fastdfs/FdfsTest.java
new file mode 100644
index 0000000..fc3eea8
--- /dev/null
+++ b/src/test/java/org/csource/fastdfs/FdfsTest.java
@@ -0,0 +1,99 @@
+package org.csource.fastdfs;
+
+import org.csource.common.NameValuePair;
+import org.junit.After;
+import org.junit.Assert;
+import org.junit.Before;
+import org.junit.Test;
+import org.slf4j.Logger;
+import org.slf4j.LoggerFactory;
+
+import java.io.*;
+import java.util.Arrays;
+
+/**
+ * @author chengdu
+ * @date 2019/7/13.
+ */
+public class FdfsTest {
+
+ private static final Logger LOGGER = LoggerFactory.getLogger(FdfsTest.class);
+
+ private static final String CONF_NAME = "fdfstest.conf";
+
+ private StorageClient storageClient;
+
+ private TrackerServer trackerServer;
+
+ @Before
+ public void initStorageClient() throws Exception {
+ ClientGlobal.init(CONF_NAME);
+ LOGGER.info("network_timeout=" + ClientGlobal.g_network_timeout + "ms");
+ LOGGER.info("charset=" + ClientGlobal.g_charset);
+ TrackerClient tracker = new TrackerClient();
+ trackerServer = tracker.getConnection();
+ StorageServer storageServer = null;
+ storageClient = new StorageClient(trackerServer, storageServer);
+ }
+
+ @After
+ public void closeClient() {
+ LOGGER.info("close connection");
+ if(trackerServer != null){
+ try {
+ trackerServer.close();
+ trackerServer.finalize();
+ }catch (Exception e){
+ e.printStackTrace();
+ }catch (Throwable e){
+ e.printStackTrace();
+ }
+ }
+ }
+
+ public void writeByteToFile(byte[] fbyte, String fileName) throws IOException {
+ BufferedOutputStream bos = null;
+ FileOutputStream fos = null;
+ File file = new File(fileName);
+ try {
+ fos = new FileOutputStream(file);
+ bos = new BufferedOutputStream(fos);
+ bos.write(fbyte);
+ } catch (Exception e) {
+ e.printStackTrace();
+ } finally {
+ if (bos != null) {
+ bos.close();
+ }
+ if (fos != null) {
+ fos.close();
+ }
+ }
+ }
+
+ @Test
+ public void upload() throws Exception{
+ NameValuePair[] metaList = new NameValuePair[1];
+ String local_filename = "build.PNG";
+ metaList[0] = new NameValuePair("fileName", local_filename);
+ File file = new File("C:/Users/chengdu/Desktop/build.PNG");
+ InputStream inputStream = new FileInputStream(file);
+ int length = inputStream.available();
+ byte[] bytes = new byte[length];
+ inputStream.read(bytes);
+ String[] result = storageClient.upload_file(bytes, null, metaList);
+ LOGGER.info("result {}", Arrays.asList(result));
+ Assert.assertEquals(2, result.length);
+ }
+
+ @Test
+ public void download() throws Exception {
+ String[] uploadresult = {"group1", "M00/00/00/wKgBZV0phl2ASV1nAACk1tFxwrM3814331"};
+ byte[] result = storageClient.download_file(uploadresult[0], uploadresult[1]);
+ String local_filename = "build.PNG";
+ writeByteToFile(result, local_filename);
+ File file = new File(local_filename);
+ Assert.assertTrue(file.isFile());
+ }
+
+}
diff --git a/src/test/resources/fdfs_client.conf b/src/test/resources/fdfs_client.conf
index deb3ff5..2f3b351 100644
--- a/src/test/resources/fdfs_client.conf
+++ b/src/test/resources/fdfs_client.conf
@@ -5,4 +5,5 @@ http.tracker_http_port = 8080
http.anti_steal_token = no
http.secret_key = FastDFS1234567890
-tracker_server = 192.168.1.101:22122
+tracker_server = 10.0.11.245:22122
+tracker_server = 10.0.11.246:22122
diff --git a/src/test/resources/log4j.properties b/src/test/resources/log4j.properties
new file mode 100644
index 0000000..dbcafc8
--- /dev/null
+++ b/src/test/resources/log4j.properties
@@ -0,0 +1,12 @@
+log4j.rootLogger=INFO, Console ,File
+
+#Console
+log4j.appender.Console=org.apache.log4j.ConsoleAppender
+log4j.appender.Console.layout=org.apache.log4j.PatternLayout
+log4j.appender.Console.layout.ConversionPattern=%d [%t] %-5p [%c] - %m%n
+
+#File
+log4j.appender.File = org.apache.log4j.FileAppender
+log4j.appender.File.File = log4j2.log
+log4j.appender.File.layout = org.apache.log4j.PatternLayout
+log4j.appender.File.layout.ConversionPattern =%d [%t] %-5p [%c] - %m%n
\ No newline at end of file