Compare commits

...

85 Commits

Author SHA1 Message Date
Johannes Zellner 9801d5e255 Bump version 2024-05-08 13:37:50 +02:00
Johannes Zellner 31b7b66a31 Update test deps 2024-05-08 12:15:44 +02:00
Johannes Zellner dce1a84d59 Update to 1.27.7 2024-05-08 12:15:03 +02:00
Johannes Zellner f57c6fce92 Bump version 2024-04-09 13:04:32 +02:00
Johannes Zellner eb13771fd7 Update test deps 2024-04-09 12:56:17 +02:00
Johannes Zellner 81d73ad09e Update to 1.27.6 2024-04-09 12:56:07 +02:00
Girish Ramakrishnan 3858cac612 typo 2024-04-02 10:08:57 +02:00
Girish Ramakrishnan 40d2f5626e Version 1.26.4 2024-04-02 10:08:01 +02:00
Girish Ramakrishnan e73e316292 Update test packages 2024-04-02 09:56:27 +02:00
Girish Ramakrishnan f651048574 Update Syncthing to 1.27.5 2024-04-02 09:52:01 +02:00
Girish Ramakrishnan 6d6ed058f7 Version 1.26.3 2024-03-05 12:15:42 +01:00
Girish Ramakrishnan df6b2725ad make tests stable 2024-03-05 12:14:53 +01:00
Girish Ramakrishnan 81277451dc Update Syncthing to 1.27.4 2024-03-05 09:33:41 +01:00
Girish Ramakrishnan e9a80dddda Version 1.26.2 2024-03-04 12:07:00 +01:00
Girish Ramakrishnan ba33f68bc8 Fix tests 2024-03-04 12:05:45 +01:00
Girish Ramakrishnan aa4cdb2de9 Update Syncthing to 1.27.3 2024-03-04 11:29:33 +01:00
Girish Ramakrishnan 302849a50f Version 1.26.1 2024-01-02 11:25:57 +01:00
Girish Ramakrishnan d8b6645f14 Fix tests 2024-01-02 11:05:43 +01:00
Girish Ramakrishnan d6ab9d25ba Update test packages 2024-01-02 11:02:22 +01:00
Girish Ramakrishnan 4209af8927 Update Syncthing to 1.27.2 2024-01-02 09:53:16 +01:00
Girish Ramakrishnan 1fabf3766e Version 1.26.0-1 2023-12-12 12:39:31 +01:00
Girish Ramakrishnan e276328b3b Remove admin note
there is no admin. just one user
2023-12-12 12:39:15 +01:00
Girish Ramakrishnan 15c363a5f7 Version 1.26.0 2023-12-12 11:33:35 +01:00
Girish Ramakrishnan 575262b21e Update test packages 2023-12-12 11:17:31 +01:00
Vladimir D 76ed36f766 LDAP auth implemented 2023-12-11 15:21:30 +04:00
Johannes Zellner 4f5c579e4c Update test deps 2023-12-11 10:58:44 +01:00
Johannes Zellner 687d751dd9 Bump version 2023-12-11 10:58:34 +01:00
Johannes Zellner 20eefea761 Fixup tests 2023-11-15 14:34:12 +01:00
Johannes Zellner 0a81bc61d4 Bump version 2023-11-15 14:22:16 +01:00
Johannes Zellner 19bdaba65f Bump version 2023-11-13 16:07:56 +01:00
Johannes Zellner 9805180643 Fixup test for real login form 2023-11-13 15:54:18 +01:00
Johannes Zellner daccdb9237 Update test deps 2023-11-13 14:34:22 +01:00
Girish Ramakrishnan 14fcde4cd4 Update Syncthing to 1.26.0 2023-11-13 12:46:24 +01:00
Girish Ramakrishnan 688e6d53a1 remove unneeded test 2023-10-11 11:06:56 +05:30
Girish Ramakrishnan ae4e726aa9 asyncify 2023-10-11 11:00:23 +05:30
Girish Ramakrishnan 67383ed187 Version 1.24.0 2023-10-11 10:53:39 +05:30
Girish Ramakrishnan 4e734b3323 Fix tests 2023-10-11 10:47:49 +05:30
Girish Ramakrishnan 83578811b0 Update test packages 2023-10-11 10:43:37 +05:30
Girish Ramakrishnan 6da37e33bd Update base image 2023-10-11 09:48:06 +05:30
Johannes Zellner e700619300 Update test deps 2023-10-03 11:34:52 +02:00
Johannes Zellner f7bb7204b6 Bump version 2023-10-03 11:33:43 +02:00
Johannes Zellner cae5e00af6 Update test deps 2023-08-09 12:28:37 +02:00
Johannes Zellner d6be72d813 Bump version 2023-08-09 12:28:17 +02:00
Johannes Zellner fc73e5c5b1 Update test deps 2023-07-04 16:21:28 +02:00
Johannes Zellner b5adb26208 Bump version 2023-07-04 16:21:13 +02:00
Girish Ramakrishnan 3a5d4f6db9 Version 1.22.5-1 2023-06-07 16:26:43 +05:30
Girish Ramakrishnan a528e3875a Fix tricky version numbers 2023-06-07 16:26:04 +05:30
Johannes Zellner c5aab1b7a2 Update test deps 2023-06-07 10:06:25 +02:00
Johannes Zellner f505dd5038 Bump version 2023-06-07 10:06:13 +02:00
Johannes Zellner ac3fb1babf Fixup version in changelog 2023-04-05 18:15:01 +02:00
Johannes Zellner 4682a67954 Bump version 2023-04-05 17:44:06 +02:00
Johannes Zellner 962fd84ce7 Update test deps 2023-04-04 12:56:51 +02:00
Johannes Zellner 526893806a Bump version 2023-04-04 12:56:34 +02:00
Girish Ramakrishnan f3a06ced68 Version 1.23.2 2023-03-08 09:59:50 +01:00
Girish Ramakrishnan b7448113c9 Update Syncthing to 1.23.2 2023-03-08 09:55:13 +01:00
Johannes Zellner 03858b79ce Fixup changelog version 2023-02-25 11:49:04 +01:00
Johannes Zellner e2c9e659ba Update test deps 2023-02-25 11:42:18 +01:00
Johannes Zellner 8a6c78328d Bump version 2023-02-25 11:39:36 +01:00
Girish Ramakrishnan a7fe5487c6 typo 2023-01-02 12:42:09 +01:00
Girish Ramakrishnan 49273738a1 Version 1.22.0 2023-01-02 12:41:34 +01:00
Girish Ramakrishnan 0d570bd00a Update Syncthing to 1.23.0 2023-01-02 11:55:02 +01:00
Girish Ramakrishnan cdebb682e7 Version 1.21.2 2022-12-24 12:04:24 +01:00
Girish Ramakrishnan dbfcedbdab Update base image to 4.0.0 2022-12-24 11:41:48 +01:00
Girish Ramakrishnan c9c919c948 Version 1.21.1 2022-11-02 12:15:54 +01:00
Girish Ramakrishnan a3fd6f5aec Update test packages 2022-11-02 11:42:59 +01:00
Girish Ramakrishnan d44cbc7900 Update SyncThing to 1.22.1 2022-11-02 11:27:18 +01:00
Girish Ramakrishnan ff4677b123 Version 1.21.0 2022-10-04 09:37:29 +02:00
Girish Ramakrishnan 02cd67842b Update SyncThing to 1.22.0 2022-10-04 09:30:38 +02:00
Johannes Zellner f9b26a945c Update test deps 2022-08-02 11:38:00 +02:00
Johannes Zellner 86edd041dc Bump version 2022-08-02 11:37:50 +02:00
Johannes Zellner 2969543a92 Update test deps 2022-07-05 10:43:31 +02:00
Johannes Zellner 81417754cc Bump version 2022-07-05 10:42:58 +02:00
Johannes Zellner f0f126d774 Update test deps 2022-06-07 13:54:10 +02:00
Johannes Zellner 293ff36607 Bump version for 1.20.2 2022-06-07 13:53:35 +02:00
Girish Ramakrishnan ea40502236 Version 1.20.1 2022-05-04 13:09:25 -07:00
Girish Ramakrishnan df82aa0431 Update syncthing to 1.20.1 2022-05-04 12:51:05 -07:00
Girish Ramakrishnan d1a847a12b const 2022-05-03 14:51:39 -07:00
Johannes Zellner 313b4beeec Bump version for 1.20.0 2022-05-03 17:56:33 +02:00
Girish Ramakrishnan 9d1858500b Version 1.19.2 2022-05-02 11:18:38 -07:00
Girish Ramakrishnan fe61a708f1 Update packages 2022-05-02 11:06:13 -07:00
Girish Ramakrishnan 71b18b17be Update syncthing to 1.19.2 2022-05-02 11:04:36 -07:00
Johannes Zellner 2cebdea6a6 Update test deps 2022-03-01 12:23:42 +01:00
Johannes Zellner bdf8642472 Bump version for 1.19.1 2022-03-01 12:23:28 +01:00
Johannes Zellner 69b36eb6af Update test deps 2022-02-01 14:50:37 +01:00
Johannes Zellner 504d758112 Bump version for 1.19.0 2022-02-01 14:50:13 +01:00
9 changed files with 1033 additions and 1109 deletions

210
CHANGELOG
View File

@ -265,3 +265,213 @@
* #8014: Send TLS SNI to relay server
* #8021: Provide a way to preset GUI credentials with password hashing
[1.19.0]
* Update Syncthing to 1.19.0
* [Full changelog](https://github.com/syncthing/syncthing/releases/tag/v1.19.0)
* #8103: API: /rest/system/connections has misleading "total" entries
* #7428: Add ignore patterns to folder defaults
* #8090: Allow specifying ports in --generate
[1.19.1]
* Update Syncthing to 1.19.1
* [Full changelog](https://github.com/syncthing/syncthing/releases/tag/v1.19.1)
* #7850: junctionsAsDirs requires folder pause and resume to trigger
* #7924: notify: File mode change events not emitted on MacOS/FSEvents watcher
* #8083: Device ID should be read-only and "nearby devices" should be hidden when adding a new pending device
* #8143: Behavior of discovery server doesn't match documentation
* #8145: Folder ID not editable in add folder dialog
* #7942: Improve error message about folder marker outside of folder
* #8130: CLI: add command to print pending folders offered by specific device
[1.19.2]
* Update Syncthing to 1.19.2
* [Full changelog](https://github.com/syncthing/syncthing/releases/tag/v1.19.2)
* Make error message upon reaching the free space quota more clear
[1.20.0]
* Update Syncthing to 1.20.0
* [Full changelog](https://github.com/syncthing/syncthing/releases/tag/v1.20.0)
* #7855: Watching for changes using too many system resources on BSDs (kqueue)
* #8020: Dangling symlink prevents filesystem watcher on Solaris
* #8232: Missing include file endlessly spams log
* #8258: The latest version does not support go1.18 compilation!!
* #8261: TypeError: Cannot read properties of null (reading 'status') in the GUI after killing Syncthing
* #8202: Indicate folders / devices where the remote end has not accepted sharing.
* #8282: Change default log format to include date
[1.20.1]
* Update Syncthing to 1.20.1
* [Full changelog](https://github.com/syncthing/syncthing/releases/tag/v1.20.1)
* #8320: Spurious failure of new connections ("unknown (newer?) version of the protocol" etc)
[1.20.2]
* Update Syncthing to 1.20.2
* [Full changelog](https://github.com/syncthing/syncthing/releases/tag/v1.20.2)
* Fix use of old, renamed function in edit folder sharing tab.
[1.20.3]
* Update Syncthing to 1.20.3
* [Full changelog](https://github.com/syncthing/syncthing/releases/tag/v1.20.3)
* #8369: Shared device names are missing from "Edit Folder -> Sharing"
* #8376: Chrome Autofill Breaks Authentication
* #8386: Ignore patterns with wildcard and non-ASCII characters don't work as expected
* #8393: Warn if two devices are introducers to each other
[1.20.4]
* Update Syncthing to 1.20.4
* [Full changelog](https://github.com/syncthing/syncthing/releases/tag/v1.20.4)
* #7458: Syncthing announces address of interface which is down
* #8479: Panic in failure reporting
* #8007: Support listing the discovered devices using the cli
[1.21.0]
* Update Syncthing to 1.22.0
* [Full changelog](https://github.com/syncthing/syncthing/releases/tag/v1.22.0)
* #2698: Sync extended file attributes on supported file systems
* #7603: WebUI tooltip inconsistencies
* #8506: macOS Monterey 12.5.1 aliases break after sync
[1.21.1]
* Update Syncthing to 1.22.1
* [Full changelog](https://github.com/syncthing/syncthing/releases/tag/v1.22.1)
* #8084: Scope ID should be filtered out of IPv6 addresses when using Remote GUI
* #8569: Periodic connection losses to webui because docker image doesn't support upgrade
* #8594: Extended attributes are only synced one way
[1.21.2]
* Update base image to 4.0.0
[1.22.0]
* Update Syncthing to 1.23.0
* [Full changelog](https://github.com/syncthing/syncthing/releases/tag/v1.23.0)
* #8572: Incorrect rescan interval on auto accepted encrypted folder
* #8646: Perhaps the list of devices contains empty elements
* #8686: Properly indicate whether a connection is "LAN" or not in the GUI
[1.22.1]
* Update Syncthing to 1.23.1
* [Full changelog](https://github.com/syncthing/syncthing/releases/tag/v1.23.1)
* #8325: "accept: function not implemented" after upgrading to syncthing v1.20.1
[1.22.2]
* Update Syncthing to 1.23.2
* [Full changelog](https://github.com/syncthing/syncthing/releases/tag/v1.23.2)
* #8749: Relay listener does not restart sometimes
* #8660: GUI editor for xattr filter patterns
* #8781: gui: Remove duplicate Spanish translation
[1.22.3]
* Update Syncthing to 1.23.3
* [Full changelog](https://github.com/syncthing/syncthing/releases/tag/v1.23.3)
* #5408: Selection of time in versions GUI not possible without editing the string inside the textfield
* #8277: Mutual encrypted sharing doesn't work (both sides with password)
* #8556: Increased file size when sharing between encrypted devices
* #8599: Key generation at connect time is slow for encrypted connections
* #7859: Allow sub-second watcher delay (use case: remote development)
* #8828: cmd/stdiscosrv: TestDatabaseGetSet flake
[1.22.4]
* Update Syncthing to 1.23.4
* [Full changelog](https://github.com/syncthing/syncthing/releases/tag/v1.23.4)
* lib/syncthing: Handle successful global migration (fixes #8851) (#8852)
* lib/syncthing: Handle successfull global migration (fixes #8851)
[1.22.5]
* Update Syncthing to 1.23.5
* [Full changelog](https://github.com/syncthing/syncthing/releases/tag/v1.23.5)
* gui: Avoid code generating HTML (#8923)
[1.22.6]
* Update Syncthing to 1.23.6
* [Full changelog](https://github.com/syncthing/syncthing/releases/tag/v1.23.6)
[1.22.7]
* Update Syncthing to 1.23.7
* [Full changelog](https://github.com/syncthing/syncthing/releases/tag/v1.23.7)
* #6597: setLowPriority should not increase process priority when already lower (in Windows)
* #7698: ursrv: unrealistic uptime data, likely due to unset RTC (1970-01-01)
* #8958: Extended attribute filter editor should be enabled when "send extended attributes" is checked
* #8967: Shared With list ends with comma on 1 device
* #9001: relaysrv crash after some weeks of operation
* #8890: Do not autoexpand tilde sign (~) to an absolute home directory path
* #8957: Add environment variables for --home, --conf, and --data
* #8968: Error for Windows invalid file names should indicate the invalid character or name part
* #8983: Integrate govulncheck
[1.23.0]
* Update Syncthing to 1.24.0
* [Full changelog](https://github.com/syncthing/syncthing/releases/tag/v1.25.0)
* #8274: Usage report transport type is wrong for QUIC
* #8482: Discovery server keeps duplicate entries
* #9019: Web GUI loses config changes when doing multiple modifications (e.g. on slow hardware or remotely)
* #9112: panic: counter cannot decrease in value
* #9123: Hashed passwords via API are hashed again
* #141: Use multiple simultaneous TCP connections
* #5607: Move footer links to header
[1.24.0]
* Update base image to 4.2.0
[1.25.0]
* Update Syncthing to 1.26.0
* [Full changelog](https://github.com/syncthing/syncthing/releases/tag/v1.26.0)
* #9106: Posting config with invalid versioner type causes panic
* #9120: Deduplicated files on Windows aren't treated as regular files any more (Go 1.21)
* #9133: Syncthing Docker container fails to start if underlying filesystem doesn't support chown
* #9143: traefik no longer url escape X-Forwarded-Tls-Client-Cert header
* #9149: Favicon is stuck in notify state
* #4137: Use a real login screen + sessions instead of HTTP basic auth
[1.25.1]
* Update Syncthing to 1.26.1
* [Full changelog](https://github.com/syncthing/syncthing/releases/tag/v1.26.1)
[1.25.2]
* Update Syncthing to 1.27.1
* [Full changelog](https://github.com/syncthing/syncthing/releases/tag/v1.27.1)
* #9253: Permission error on folder causes "connection error" dialog when opening folder editor
* #9269: panic: nil pointer dereference in (*indexHandlerRegistry).startLocked
* #9274: Missing lock in DeviceStatistics ("fatal error: concurrent map read and map write")
[1.26.0]
* Add LDAP support
[1.26.1]
* Update Syncthing to 1.27.2
* [Full changelog](https://github.com/syncthing/syncthing/releases/tag/v1.27.2)
* #9041: cli subcommand does not use STHOMEDIR env var
* #9183: Filesystem watching (kqueue) is enabled … with a lot of files
* #9274: Missing lock in DeviceStatistics ("fatal error: concurrent map read and map write")
* #7406: Add UPnP support for IPv6
[1.26.2]
* Update Syncthing to 1.27.3
* [Full changelog](https://github.com/syncthing/syncthing/releases/tag/v1.27.3)
* #9039: Sync from Linux to Mac with ownership - Local additions after rescan
* #9241: Versions path does not honor tilde (~) shortcut
* #8616: Add CLI completion
* #9151: Add "stay logged in" checkbox to login dialog
[1.26.3]
* Update Syncthing to 1.27.4
* [Full changelog](https://github.com/syncthing/syncthing/releases/tag/v1.27.4)
* #9369: Panic in ignore matching on invalid UTF-8 from filesystem watcher
* #9435: syncthing should be cgroup aware
* #9339: File system watcher should skip ignored directories in more cases
[1.26.4]
* Update Syncthing to 1.27.5
* [Full changelog](https://github.com/syncthing/syncthing/releases/tag/v1.27.5)
* #8972: Open share settings when clicking 'shared with'
* #9470: Show encryption status for devices sharing folder
[1.26.5]
* Update Syncthing to 1.27.6
* [Full changelog](https://github.com/syncthing/syncthing/releases/tag/v1.27.6)
* lib/db: Drop indexes for outgoing data to force refresh (ref #9496) (#9502)
[1.26.6]
* Update Syncthing to 1.27.7
* [Full changelog](https://github.com/syncthing/syncthing/releases/tag/v1.27.7)
* #9503: lib/nat: panic: runtime error: index out of range

View File

@ -5,11 +5,13 @@
"description": "file://DESCRIPTION.md",
"changelog": "file://CHANGELOG",
"tagline": "Decentralized file synchronization",
"version": "1.18.5",
"version": "1.26.6",
"upstreamVersion": "1.27.7",
"healthCheckPath": "/healthcheck",
"httpPort": 8000,
"addons": {
"localstorage": {}
"localstorage": {},
"ldap": {}
},
"tcpPorts": {
"SYNC_PORT": {
@ -27,7 +29,7 @@
"storage",
"sync"
],
"minBoxVersion": "5.3.0",
"minBoxVersion": "7.1.2",
"forumUrl": "https://forum.cloudron.io/category/56/syncthing",
"documentationUrl": "https://docs.cloudron.io/apps/syncthing/",
"mediaLinks": [
@ -35,5 +37,6 @@
"https://screenshots.cloudron.io/net.syncthing.cloudronapp2/2.png",
"https://screenshots.cloudron.io/net.syncthing.cloudronapp2/3.png"
],
"optionalSso": true,
"postInstallMessage": "file://POSTINSTALL.md"
}

View File

@ -1,5 +1,3 @@
This app packages Syncthing <upstream>1.18.5</upstream>.
Syncthing replaces proprietary sync and cloud services with something open, trustworthy and decentralized. Your data is your data alone and you deserve to choose where it is stored, if it is shared with some third party and how it's transmitted over the Internet.
### Features

View File

@ -1,9 +1,9 @@
FROM cloudron/base:3.2.0@sha256:ba1d566164a67c266782545ea9809dc611c4152e27686fd14060332dd88263ea
FROM cloudron/base:4.2.0@sha256:46da2fffb36353ef714f97ae8e962bd2c212ca091108d768ba473078319a47f4
RUN mkdir -p /app/code
WORKDIR /app/code
ARG VERSION=1.18.5
ARG VERSION=1.27.7
RUN wget https://github.com/syncthing/syncthing/releases/download/v${VERSION}/syncthing-linux-amd64-v${VERSION}.tar.gz -O - | tar -xz -C /app/code --strip-components=1

View File

@ -1,7 +1,13 @@
This app is pre-setup with an admin account. The initial credentials are:
<nosso>
This app is pre-setup with an account. The initial credentials are:
**Username**: admin<br/>
**Password**: changeme<br/>
Please change the admin password immediately.
</nosso>
<sso>
Note that all users manage and synchronize the same set of files.
</sso>

View File

@ -17,8 +17,21 @@ if [[ ! -f /app/data/config/config.xml ]]; then
--update "//configuration/options/defaultFolderPath" -v '/app/data/folders' \
--update "//configuration/options/urAccepted" -v '-1' \
/app/data/config/config.xml
fi
if [[ -n ${CLOUDRON_LDAP_HOST:-} ]]; then
xmlstarlet ed --inplace \
--subnode "//configuration/gui" -t elem -n "authMode" -v "ldap" \
--subnode "//configuration/ldap" -t elem -n "address" -v "${CLOUDRON_LDAP_HOST:-}:${CLOUDRON_LDAP_PORT}" \
--subnode "//configuration/ldap" -t elem -n "bindDN" -v "${CLOUDRON_LDAP_BIND_DN:-}" \
--subnode "//configuration/ldap" -t elem -n "insecureSkipVerify" -v "true" \
--subnode "//configuration/ldap" -t elem -n "searchBaseDN" -v "${CLOUDRON_LDAP_USERS_BASE_DN:-}" \
--subnode "//configuration/ldap" -t elem -n "searchFilter" -v "(&amp;(objectclass=user)(|(username=%s)(mail=%s)))" \
/app/data/config/config.xml
fi
# Set the listenAddress and the gui enabled to make sure user doesnt lock themselves out by accident.
sed -e "s,<listenAddress>.*</listenAddress>,<listenAddress>tcp://:${SYNC_PORT}</listenAddress>," -i /app/data/config/config.xml
sed -e 's,<gui .*>,<gui enabled="true" tls="false" debugging="false">,' -i /app/data/config/config.xml

1690
test/package-lock.json generated

File diff suppressed because it is too large Load Diff

View File

@ -9,10 +9,9 @@
"author": "",
"license": "ISC",
"dependencies": {
"chromedriver": "^96.0.0",
"chromedriver": "^124.0.1",
"expect.js": "^0.3.1",
"mocha": "^9.1.3",
"selenium-webdriver": "^4.1.0",
"superagent": "^6.1.0"
"mocha": "^10.4.0",
"selenium-webdriver": "^4.20.0"
}
}

View File

@ -5,30 +5,37 @@
/* global before */
/* global after */
/* global it */
/* global xit */
'use strict';
require('chromedriver');
var execSync = require('child_process').execSync,
const execSync = require('child_process').execSync,
expect = require('expect.js'),
superagent = require('superagent'),
path = require('path'),
{ Builder, By, Key, until } = require('selenium-webdriver'),
timers = require('timers/promises'),
{ Builder, By, until } = require('selenium-webdriver'),
{ Options } = require('selenium-webdriver/chrome');
if (!process.env.USERNAME || !process.env.PASSWORD) {
console.log('USERNAME and PASSWORD env vars need to be set');
process.exit(1);
}
describe('Application life cycle test', function () {
this.timeout(0);
var LOCATION = 'test';
var TEST_TIMEOUT = 30000;
var FOLDER = 'xmf'; // keep this small. long folder names fail in automation, not sure why
var SYNC_PORT = 22001;
var EXEC_ARGS = { cwd: path.resolve(__dirname, '..'), stdio: 'inherit' };
const LOCATION = 'test';
const TEST_TIMEOUT = 30000;
const FOLDER = 'xmf'; // keep this small. long folder names fail in automation, not sure why
const SYNC_PORT = 22001;
const EXEC_ARGS = { cwd: path.resolve(__dirname, '..'), stdio: 'inherit' };
var browser;
var app;
var username = 'admin', password = 'changeme';
let browser, app;
const adminUsername = 'admin', adminPassword = 'changeme';
let username = process.env.USERNAME;
let password = process.env.PASSWORD;
before(function () {
browser = new Builder().forBrowser('chrome').setChromeOptions(new Options().windowSize({ width: 1280, height: 1024 })).build();
@ -39,138 +46,110 @@ describe('Application life cycle test', function () {
});
function getAppInfo() {
var inspect = JSON.parse(execSync('cloudron inspect'));
const inspect = JSON.parse(execSync('cloudron inspect'));
app = inspect.apps.filter(function (a) { return a.location.indexOf(LOCATION) === 0; })[0];
expect(app).to.be.an('object');
}
function waitForElement(elem) {
return browser.wait(until.elementLocated(elem), TEST_TIMEOUT).then(function () {
return browser.wait(until.elementIsVisible(browser.findElement(elem)), TEST_TIMEOUT);
});
async function waitForElement(elem) {
await browser.wait(until.elementLocated(elem), TEST_TIMEOUT);
await browser.wait(until.elementIsVisible(browser.findElement(elem)), TEST_TIMEOUT);
}
function invalidPassword(callback) {
superagent.get('https://' + app.fqdn).auth(username, password + 'x').end(function (error, result) {
expect(result.status).to.eql(401);
callback();
});
async function login(username, password) {
await browser.manage().deleteAllCookies();
await browser.get('https://' + app.fqdn);
await waitForElement(By.id('user'));
await browser.findElement(By.id('user')).sendKeys(username);
await browser.findElement(By.id('password')).sendKeys(password);
await browser.findElement(By.xpath('//button[@type="submit"]')).click();
await waitForElement(By.xpath('//span[text()="Actions"]'));
}
function loadPage(callback) {
browser.manage().deleteAllCookies().then(function () {
return browser.sleep(5000);
}).then(function() {
return browser.get('https://' + username + ':' + encodeURIComponent(password) + '@' + app.fqdn).then(function () {
return browser.get('https://' + app.fqdn);
});
}).then(function () {
return browser.sleep(5000);
}).then(function () {
return browser.get('https://' + app.fqdn);
}).then(function () {
return waitForElement(By.xpath('//span[text()="Actions"]'));
}).then(function () {
callback();
});
async function logout() {
await browser.get('https://' + app.fqdn);
await waitForElement(By.xpath('//span[text()="Actions"]'));
await browser.findElement(By.xpath('//span[text()="Actions"]')).click();
await browser.sleep(4000);
await waitForElement(By.xpath('//span[text()="Log Out"]'));
await browser.findElement(By.xpath('//span[text()="Log Out"]')).click();
await browser.sleep(4000);
await waitForElement(By.id('user'));
}
function addFolder(callback) {
browser.get('https://' + app.fqdn).then(function () {
return browser.findElement(By.css('[ng-click*=addFolder]')).click();
}).then(function () {
return waitForElement(By.id('folderPath'));
}).then(function () {
return browser.sleep(4000); // wait more, not sure why this is needed
}).then(function() {
return browser.findElement(By.id('folderLabel')).sendKeys(FOLDER);
}).then(function () {
return browser.sleep(4000); // without this sometimes only part of the folder name gets through
}).then(function() {
return browser.findElement(By.css('[ng-click*=saveFolder]')).click();
}).then(function() {
return browser.wait(until.elementLocated(By.css('#folders .panel-status span[ng-switch-when=unshared]')), TEST_TIMEOUT);
}).then(function () {
return browser.sleep(4000);
}).then(function() {
callback();
});
async function loadPage() {
await browser.get('https://' + app.fqdn);
await waitForElement(By.xpath('//span[text()="Actions"]'));
}
function checkFolder(callback) {
browser.get('https://' + app.fqdn).then(function () {
return browser.sleep(5000);
}).then(function () {
return browser.get('https://' + app.fqdn);
}).then(function () {
return browser.wait(until.elementLocated(By.xpath(`//span[text()="${FOLDER}"]`)), TEST_TIMEOUT);
}).then(function () {
callback();
});
async function addFolder() {
await browser.get('https://' + app.fqdn);
await browser.findElement(By.css('[ng-click*=addFolder]')).click();
await waitForElement(By.id('folderPath'));
await browser.sleep(8000); // wait more, not sure why this is needed
await browser.findElement(By.id('folderLabel')).sendKeys(FOLDER);
await browser.sleep(8000); // without this sometimes only part of the folder name gets through
await browser.findElement(By.css('[ng-click*=saveFolder]')).click();
await browser.sleep(8000); // without this "stale element"
await waitForElement(By.xpath(`//span[contains(text(), '${FOLDER}')]`));
await browser.sleep(8000);
}
function removeFolder(callback) {
browser.get('https://' + app.fqdn).then(function () {
return waitForElement(By.xpath('//span[text()="Actions"]'));
}).then(function() {
return browser.findElement(By.css('#folders button')).click();
}).then(function () {
return browser.sleep(3000); //No way to check for visibility of angular-js components
}).then(function () {
return browser.findElement(By.css('#folder-0 button[ng-click*=editFolder]')).click();
}).then(function () {
return browser.sleep(3000); //No way to check for visibility of angular-js components
}).then(function () {
return browser.findElement(By.xpath('//button[@data-target="#remove-folder-confirmation"]')).click();
}).then(function () {
return browser.sleep(3000); //No way to check for visibility of angular-js components
}).then(function () {
return browser.findElement(By.css('[ng-click*=deleteFolder]')).click();
}).then(function () {
return browser.sleep(3000); //This needs to run for some time
}).then(function () {
callback();
});
}
function wait (done) {
setTimeout(done, 10000);
async function checkFolder() {
await browser.get('https://' + app.fqdn);
await browser.sleep(5000);
await browser.get('https://' + app.fqdn);
await browser.wait(until.elementLocated(By.xpath(`//span[text()="${FOLDER}"]`)), TEST_TIMEOUT);
}
xit('build app', function () { execSync('cloudron build', EXEC_ARGS); });
it('install app', function () { execSync('cloudron install --port-bindings SYNC_PORT=' + SYNC_PORT + ' --location ' + LOCATION, EXEC_ARGS); });
// NO SSO
it('install app (NO SSO)', function () { execSync('cloudron install --no-sso --port-bindings SYNC_PORT=' + SYNC_PORT + ' --location ' + LOCATION, EXEC_ARGS); });
it('can get app information', getAppInfo);
it('wait', wait);
it('fails with invalid password', invalidPassword);
it('can admin login', login.bind(null, adminUsername, adminPassword));
it('can load page', loadPage);
it('can add folder', addFolder);
it('can check folder', checkFolder);
it('backup app', function () { execSync('cloudron backup create --app ' + app.id, EXEC_ARGS); });
it('uninstall app', async function () {
await browser.get('about:blank');
execSync('cloudron uninstall --app ' + app.id, EXEC_ARGS);
});
// SSO
it('install app (SSO)', function () { execSync('cloudron install --port-bindings SYNC_PORT=' + SYNC_PORT + ' --location ' + LOCATION, EXEC_ARGS); });
it('can get app information', getAppInfo);
it('can login', login.bind(null, username, password));
it('can load page', loadPage);
it('can add folder', addFolder);
it('can logout', logout);
it('backup app', async function () { execSync('cloudron backup create --app ' + app.id, EXEC_ARGS); });
it('restore app', async function () {
await browser.get('about:blank');
execSync('cloudron restore --app ' + app.id, EXEC_ARGS);
await timers.setTimeout(5000);
});
it('wait', wait);
it('can login', login.bind(null, username, password));
it('can load page', loadPage);
it('can check folder', checkFolder);
it('can logout', logout);
it('move to different location', async function () {
await browser.get('about:blank');
execSync(`cloudron configure --location ${LOCATION}2 --app ${app.id}`, EXEC_ARGS);
await timers.setTimeout(5000);
});
it('can get app information', getAppInfo);
it('wait', wait);
it('can login', login.bind(null, username, password));
it('can load page', loadPage);
it('can check folder', checkFolder);
it('can remove folder', removeFolder);
it('can logout', logout);
it('uninstall app', async function () {
await browser.get('about:blank');
@ -178,16 +157,22 @@ describe('Application life cycle test', function () {
});
// test update
it('can install app', function () { execSync('cloudron install --port-bindings SYNC_PORT=' + SYNC_PORT + ' --appstore-id net.syncthing.cloudronapp2 --location ' + LOCATION, EXEC_ARGS); });
it('can install app', async function () {
execSync('cloudron install --port-bindings SYNC_PORT=' + SYNC_PORT + ' --appstore-id net.syncthing.cloudronapp2 --location ' + LOCATION, EXEC_ARGS);
await timers.setTimeout(30000);
});
it('can get app information', getAppInfo);
it('wait', wait);
it('can login', login.bind(null, username, password));
it('can load page', loadPage);
it('can add folder', addFolder);
it('can logout', logout);
it('can update', async function () {
await browser.get('about:blank');
execSync('cloudron update --app ' + LOCATION, EXEC_ARGS);
await timers.setTimeout(30000);
});
it('wait', wait);
it('can login', login.bind(null, username, password));
it('can check folder', checkFolder);
it('uninstall app', async function () {