Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -54,6 +54,7 @@
import java.util.Locale;
import java.util.TimeZone;

import androidx.annotation.Nullable;
import androidx.core.app.ActivityCompat;
import edu.umd.cs.findbugs.annotations.SuppressFBWarnings;

Expand Down Expand Up @@ -164,15 +165,17 @@ private static String getSubPathFromDate(long date, Locale currentLocale) {
*/
public static String getInstantUploadFilePath(Locale current,
String remotePath,
String fileName,
@Nullable String fileName,
long dateTaken,
Boolean subfolderByDate) {
String subPath = "";
if (subfolderByDate) {
subPath = getSubPathFromDate(dateTaken, current);
}

return remotePath + OCFile.PATH_SEPARATOR + subPath + (fileName == null ? "" : fileName);
// Path must be normalized; otherwise the next RefreshFolderOperation has a mismatch and deletes the local file.
return (remotePath + OCFile.PATH_SEPARATOR + subPath + (fileName == null ? "" : fileName))
.replaceAll(OCFile.PATH_SEPARATOR + "+", OCFile.PATH_SEPARATOR);
}


Expand Down
101 changes: 101 additions & 0 deletions src/test/java/com/nextcloud/client/utils/FileStorageUtilsTest.kt
Original file line number Diff line number Diff line change
@@ -0,0 +1,101 @@
/*
* Nextcloud Android client application
*
* @author Tobias Kaminsky
* Copyright (C) 2019 Tobias Kaminsky
* Copyright (C) 2019 Nextcloud GmbH
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <https://www.gnu.org/licenses/>.
*/

package com.nextcloud.client.utils

import com.owncloud.android.utils.FileStorageUtils
import org.junit.Assert.assertEquals
import org.junit.Test
import java.util.Locale

class FileStorageUtilsTest {
@Test
fun testInstantUploadPathNullFilename() {
val result = FileStorageUtils.getInstantUploadFilePath(Locale.ROOT,
"/subfolder/",
null,
123123123L,
false)
val expected = "/subfolder/"

assertEquals(expected, result)
}

@Test
fun testInstantUploadPathNullEmptyDate() {
val result = FileStorageUtils.getInstantUploadFilePath(Locale.ROOT,
"/subfolder/",
"file.pdf",
0,
true)
val expected = "/subfolder/file.pdf"

assertEquals(expected, result)
}

@Test
fun testInstantUploadPath() {
val result = FileStorageUtils.getInstantUploadFilePath(Locale.ROOT,
"/subfolder/",
"file.pdf",
123123123L,
false)
val expected = "/subfolder/file.pdf"

assertEquals(expected, result)
}

@Test
fun testInstantUploadPathWithSubfolderByDate() {
val result = FileStorageUtils.getInstantUploadFilePath(Locale.ROOT,
"/subfolder/",
"file.pdf",
1569918628000,
true)
val expected = "/subfolder/2019/10/file.pdf"

assertEquals(expected, result)
}

@Test
fun testInstantUploadPathWithSubfolderFile() {
val result = FileStorageUtils.getInstantUploadFilePath(Locale.ROOT,
"/subfolder/",
"/sub/file.pdf",
123123123L,
false)
val expected = "/subfolder/sub/file.pdf"

assertEquals(expected, result)
}

@Test
fun testInstantUploadPathWithSubfolderByDateWithSubfolderFile() {
val result = FileStorageUtils.getInstantUploadFilePath(Locale.ROOT,
"/subfolder/",
"/sub/file.pdf",
1569918628000,
true)
val expected = "/subfolder/2019/10/sub/file.pdf"

assertEquals(expected, result)
}
}