1
0
mirror of https://git.cloudron.io/cloudron/syncthing-app synced 2025-09-13 00:15:14 +00:00

Compare commits

...

41 Commits

Author SHA1 Message Date
Johannes Zellner
dfd2b058ec Update to lockfile v2 2022-01-02 09:58:59 +01:00
Johannes Zellner
f00e65442b Bump version for 1.18.5 2022-01-02 09:58:45 +01:00
Girish Ramakrishnan
02eacdc619 Version 1.18.4 2021-11-02 11:13:17 -07:00
Girish Ramakrishnan
7effe3834e Update syncthing to 1.18.4 2021-11-02 11:03:32 -07:00
Girish Ramakrishnan
d9b68bec93 Version 1.18.3 2021-10-05 09:08:48 -07:00
Girish Ramakrishnan
a5f275e817 Update Syncthing to 1.18.3 2021-10-05 09:03:35 -07:00
Girish Ramakrishnan
ddc1727671 Version 1.18.2 2021-10-04 10:39:44 -07:00
Girish Ramakrishnan
21dfd65456 Update test packages 2021-10-04 10:39:38 -07:00
Girish Ramakrishnan
c8e0d8aece Update syncthing to 1.18.2 2021-10-04 10:34:18 -07:00
Girish Ramakrishnan
77908fb319 Version 1.18.1 2021-08-03 21:14:01 -07:00
Girish Ramakrishnan
ac8201d0fd Update test packages 2021-08-03 20:59:38 -07:00
Girish Ramakrishnan
b0d566645a Update syncthing to 1.18.1 2021-08-03 20:08:29 -07:00
Girish Ramakrishnan
5d87c13269 Version 1.18.0 2021-07-12 09:44:30 -07:00
Girish Ramakrishnan
f3a6a74028 Update syncthing to 1.18.0 2021-07-12 09:19:29 -07:00
Girish Ramakrishnan
29d09bf7bd Version 1.17.0 2021-07-12 09:18:56 -07:00
Girish Ramakrishnan
0a69ac3577 Update test packages 2021-07-12 09:11:55 -07:00
Girish Ramakrishnan
ab8a2af60d Update syncthing to 1.17.0 2021-07-12 09:10:17 -07:00
Johannes Zellner
1416ab42fd Bump version for 1.16.1 2021-05-06 10:36:24 +02:00
Johannes Zellner
36e9f3d435 Update test deps 2021-05-03 16:17:53 +02:00
Johannes Zellner
f32e5162a7 Bump version for 1.16.0 2021-05-03 16:13:51 +02:00
Johannes Zellner
2263288b5d Fix name typo 2021-04-08 14:37:37 +02:00
Johannes Zellner
58ca4d15bd Bump version for 1.15.1 2021-04-06 11:39:45 +02:00
Johannes Zellner
f1b0fc4097 Fixup tests 2021-04-06 11:24:39 +02:00
Johannes Zellner
cb832e1c5d Update test deps 2021-04-06 10:12:06 +02:00
Johannes Zellner
64a6e8bbf6 Bump version for 1.15.0 2021-04-06 09:51:16 +02:00
Johannes Zellner
7f64910521 Bump version for 1.14.0 2021-03-03 12:14:25 +01:00
Girish Ramakrishnan
f84cc9fc51 Version 1.13.0 2021-02-22 11:11:37 -08:00
Girish Ramakrishnan
558c36e859 Update base image to v3 2021-02-22 11:04:36 -08:00
Johannes Zellner
11ce073fa4 Update test deps 2020-12-01 17:01:53 +01:00
Johannes Zellner
52c22f57a9 Bump version for 1.12.0
This version is not yet available as a build
2020-11-30 17:45:48 +01:00
Johannes Zellner
be49e77f9d Bump version to 1.11.1 2020-11-11 21:22:52 +01:00
Johannes Zellner
b00ace5472 Improve tests, but still not working 2020-11-03 15:38:03 +01:00
Johannes Zellner
107c1abf30 Update test deps 2020-11-03 13:33:53 +01:00
Johannes Zellner
c4f75bc16d Bump version for 1.10.0 2020-11-03 13:26:18 +01:00
Girish Ramakrishnan
d0a965f323 Update screenshots 2020-09-08 09:53:05 -07:00
Girish Ramakrishnan
2f7eed47c2 Remove space 2020-09-08 09:51:47 -07:00
Johannes Zellner
ef295ffb0b Update test deps 2020-09-08 13:15:20 +02:00
Johannes Zellner
0a1c5ceed2 Bump version for 1.9.0 2020-09-08 13:14:21 +02:00
Johannes Zellner
23f4e2abd9 Update test deps 2020-08-08 11:21:10 +02:00
Girish Ramakrishnan
af1a53e0ca Revert "Bump version for 1.8.0"
This reverts commit 8ba346c847.

It seems they reverted this release
2020-08-06 10:49:32 -07:00
Johannes Zellner
8ba346c847 Bump version for 1.8.0 2020-08-03 16:18:51 +02:00
9 changed files with 2295 additions and 884 deletions

View File

@@ -168,3 +168,100 @@
* #6564: Closing an already removed connection causes GUI error message
* #6646: Misleading error message when to be deleted dir contains receive-only changes
* #6653: panic: nil pointer dereference in leveldb.(*DB).isClosed()
[1.11.0]
* Update Syncthing to 1.9.0
* [Full changelog](https://github.com/syncthing/syncthing/releases/tag/v1.9.0)
* Offline nodes after drive replacement automatically heal and join back into the cluster, refer #10416
* Listing improvements with parallel disk.Walk calls across many nodes, refer #10420
* certs now supports multiple domains for TLS termination, refer #10207
* Context now passed around at storage layer for future context support, refer #10321
[1.12.0]
* Update Syncthing to 1.11.1
* #6880: fatal error: concurrent map iteration and map write
* #6917: Reconsider db check on upgrade
* #6930: Can't add new folder with versioning enabled, Cleanup Interval field lacks default value
* #6940: TypeError: Object doesn't support property or method 'startsWith' in IE 11 / Windows 7
* #6943: Missing strings for translation
* #6961: Accounting issue with receive-only deleted files causing spurious 95% completion for remote devices
* #6968: Very slow scans on Windows in 1.9.0
* #6972: Deleting a folder containing a symlink results in a permanently out of sync on windows
* #6973: given name "syncthingxxx.tmp" differs from name in filesystem "syncthingXXX.tmp"
* #4277: Announce internal and external address to the global discovery service, encrypted
* #6734: Consider moving configuration to a proto contract
* #6928: Announce LAN addresses to global discovery
[1.12.1]
* Update Syncthing to 1.12.0
* #5360: Dangling symlink prevents filesystem watcher on FreeBSD
* #6664: Panic due to internal folder context used on exported methods
* #7063: panic: runtime error: invalid memory address or nil pointer dereference
* #7077: GUI stuck with "id is not defined" error when trying to ignore non-existent folder
* #7098: File deletions are not being synced in newly shared folders
* #6540: Config PATCH/PUT/DELETE API
* #7099: Add a html message to GUI when javascript is disabled
* #7108: Certificate for relaysrv with better naming
[1.13.0]
* Update base image to v3
[1.14.0]
* Update Syncthing to 1.14.0
* [Full changelog](https://github.com/syncthing/syncthing/releases/tag/v1.14.0)
[1.15.0]
* Update Syncthing to 1.15.0
* [Full changelog](https://github.com/syncthing/syncthing/releases/tag/v1.15.0)
[1.15.1]
* Update Syncthing to 1.15.1
* [Full changelog](https://github.com/syncthing/syncthing/releases/tag/v1.15.1)
[1.16.0]
* Update Syncthing to 1.16.0
* [Full changelog](https://github.com/syncthing/syncthing/releases/tag/v1.16.0)
[1.16.1]
* Update Syncthing to 1.16.1
* [Full changelog](https://github.com/syncthing/syncthing/releases/tag/v1.16.1)
[1.17.0]
* Update Syncthing to 1.17.0
* [Full changelog](https://github.com/syncthing/syncthing/releases/tag/v1.17.0)
[1.18.0]
* Update Syncthing to 1.18.0
* [Full changelog](https://github.com/syncthing/syncthing/releases/tag/v1.18.0)
[1.18.1]
* Update Syncthing to 1.18.1
* [Full changelog](https://github.com/syncthing/syncthing/releases/tag/v1.18.1)
[1.18.2]
* Update Syncthing to 1.18.2
* [Full changelog](https://github.com/syncthing/syncthing/releases/tag/v1.18.2)
* #7827: The error message "given name ... differs from filesystem name ..." does not help users to resolve the issue
* #7893: Updating ignores blocks GUI when IO slots are unavailable
[1.18.3]
* Update Syncthing to 1.18.3
* [Full changelog](https://github.com/syncthing/syncthing/releases/tag/v1.18.3)
[1.18.4]
* Update Syncthing to 1.18.4
* [Full changelog](https://github.com/syncthing/syncthing/releases/tag/v1.18.4)
* #7991: Encryption trailer not updated on shortcut
* #7994: Index "out of sync with reality" on receive-encrypted folder
* #8000: stdiscosrv + strelaysrv systemd services not restarting on upgrade
* #8012: Not retrying to sync when a new connection is established
[1.18.5]
* Update Syncthing to 1.18.5
* [Full changelog](https://github.com/syncthing/syncthing/releases/tag/v1.18.5)
* Update base image to 3.2.0
* #7715: Deleted encrypted files don't show up as locally changed in web UI
* #7115: Use CRLF instead of LF in config.xml and .stignore on Windows
* #8014: Send TLS SNI to relay server
* #8021: Provide a way to preset GUI credentials with password hashing

View File

@@ -5,7 +5,7 @@
"description": "file://DESCRIPTION.md",
"changelog": "file://CHANGELOG",
"tagline": "Decentralized file synchronization",
"version": "1.10.0",
"version": "1.18.5",
"healthCheckPath": "/healthcheck",
"httpPort": 8000,
"addons": {
@@ -29,11 +29,11 @@
],
"minBoxVersion": "5.3.0",
"forumUrl": "https://forum.cloudron.io/category/56/syncthing",
"documentationUrl": "https://cloudron.io/documentation/apps/syncthing/",
"documentationUrl": "https://docs.cloudron.io/apps/syncthing/",
"mediaLinks": [
"https://cloudron-app-screenshots.s3.amazonaws.com/net.syncthing.cloudronapp2/53bc9300d71bb5bf32362f8213194a0c3a415429/1.png",
"https://cloudron-app-screenshots.s3.amazonaws.com/net.syncthing.cloudronapp2/53bc9300d71bb5bf32362f8213194a0c3a415429/2.png",
"https://cloudron-app-screenshots.s3.amazonaws.com/net.syncthing.cloudronapp2/53bc9300d71bb5bf32362f8213194a0c3a415429/3.png"
"https://screenshots.cloudron.io/net.syncthing.cloudronapp2/1.png",
"https://screenshots.cloudron.io/net.syncthing.cloudronapp2/2.png",
"https://screenshots.cloudron.io/net.syncthing.cloudronapp2/3.png"
],
"postInstallMessage": "file://POSTINSTALL.md"
}

View File

@@ -1,4 +1,4 @@
This app packages Syncthing <upstream>1.7.1</upstream>.
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.

View File

@@ -1,10 +1,10 @@
FROM cloudron/base:2.0.0@sha256:f9fea80513aa7c92fe2e7bf3978b54c8ac5222f47a9a32a7f8833edf0eb5a4f4
ARG VERSION=1.7.1
FROM cloudron/base:3.2.0@sha256:ba1d566164a67c266782545ea9809dc611c4152e27686fd14060332dd88263ea
RUN mkdir -p /app/code
WORKDIR /app/code
ARG VERSION=1.18.5
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
# add supervisor configs

View File

@@ -1,7 +1,7 @@
This app is pre-setup with an admin account. The initial credentials are:
**Username**: admin <br/>
**Password**: changeme <br/>
**Username**: admin<br/>
**Password**: changeme<br/>
Please change the admin password immediately.

View File

@@ -26,4 +26,4 @@ sed -e 's,<gui .*>,<gui enabled="true" tls="false" debugging="false">,' -i /app/
chown -R cloudron:cloudron /app/data /run/syncthing
echo "Starting supervisor"
exec /usr/bin/supervisord --configuration /etc/supervisor/supervisord.conf --nodaemon -i GitLab
exec /usr/bin/supervisord --configuration /etc/supervisor/supervisord.conf --nodaemon -i syncthing

2911
test/package-lock.json generated

File diff suppressed because it is too large Load Diff

View File

@@ -9,14 +9,10 @@
"author": "",
"license": "ISC",
"dependencies": {
"chromedriver": "^83.0.0",
"ejs": "^3.1.3",
"chromedriver": "^96.0.0",
"expect.js": "^0.3.1",
"mkdirp": "^1.0.4",
"mocha": "^7.2.0",
"rimraf": "^3.0.2",
"selenium-server-standalone-jar": "^3.141.59",
"selenium-webdriver": "^3.6.0",
"superagent": "^5.2.2"
"mocha": "^9.1.3",
"selenium-webdriver": "^4.1.0",
"superagent": "^6.1.0"
}
}

View File

@@ -1,67 +1,52 @@
#!/usr/bin/env node
'use strict';
/* jshint esversion: 8 */
/* global describe */
/* global before */
/* global after */
/* global it */
'use strict';
require('chromedriver');
var execSync = require('child_process').execSync,
expect = require('expect.js'),
superagent = require('superagent'),
path = require('path'),
webdriver = require('selenium-webdriver');
var by = require('selenium-webdriver').By,
until = require('selenium-webdriver').until,
Key = require('selenium-webdriver').Key,
Builder = require('selenium-webdriver').Builder;
{ Builder, By, Key, until } = require('selenium-webdriver'),
{ Options } = require('selenium-webdriver/chrome');
describe('Application life cycle test', function () {
this.timeout(0);
var server, browser = new Builder().forBrowser('chrome').build();
var username = 'admin', password = 'changeme';
before(function (done) {
var seleniumJar= require('selenium-server-standalone-jar');
var SeleniumServer = require('selenium-webdriver/remote').SeleniumServer;
server = new SeleniumServer(seleniumJar.path, { port: 4444 });
server.start();
done();
});
after(function (done) {
browser.quit();
server.stop();
done();
});
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' };
var browser;
var app;
var username = 'admin', password = 'changeme';
before(function () {
browser = new Builder().forBrowser('chrome').setChromeOptions(new Options().windowSize({ width: 1280, height: 1024 })).build();
});
after(function () {
browser.quit();
});
function getAppInfo() {
var inspect = JSON.parse(execSync('cloudron inspect'));
app = inspect.apps.filter(function (a) { return a.location === LOCATION || a.location === LOCATION + '2'; })[0];
app = inspect.apps.filter(function (a) { return a.location.indexOf(LOCATION) === 0; })[0];
expect(app).to.be.an('object');
}
function pageLoaded() {
return browser.wait(until.titleMatches(/[0-9a-f]{12} \| Syncthing/), TEST_TIMEOUT);
}
function visible(selector) {
return browser.wait(until.elementLocated(selector), TEST_TIMEOUT).then(function () {
return browser.wait(until.elementIsVisible(browser.findElement(selector)), TEST_TIMEOUT);
function waitForElement(elem) {
return browser.wait(until.elementLocated(elem), TEST_TIMEOUT).then(function () {
return browser.wait(until.elementIsVisible(browser.findElement(elem)), TEST_TIMEOUT);
});
}
@@ -75,13 +60,17 @@ describe('Application life cycle test', function () {
function loadPage(callback) {
browser.manage().deleteAllCookies().then(function () {
return browser.sleep(10000);
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 pageLoaded();
return browser.sleep(5000);
}).then(function () {
return browser.get('https://' + app.fqdn);
}).then(function () {
return waitForElement(By.xpath('//span[text()="Actions"]'));
}).then(function () {
callback();
});
@@ -89,19 +78,19 @@ describe('Application life cycle test', function () {
function addFolder(callback) {
browser.get('https://' + app.fqdn).then(function () {
return browser.findElement(by.css('[ng-click*=addFolder]')).click();
return browser.findElement(By.css('[ng-click*=addFolder]')).click();
}).then(function () {
return visible(by.id('folderPath'));
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);
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();
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);
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() {
@@ -111,7 +100,11 @@ describe('Application life cycle test', function () {
function checkFolder(callback) {
browser.get('https://' + app.fqdn).then(function () {
return browser.wait(until.elementLocated(by.xpath(`//span[text()="${FOLDER}"]`)), TEST_TIMEOUT);
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();
});
@@ -119,21 +112,21 @@ describe('Application life cycle test', function () {
function removeFolder(callback) {
browser.get('https://' + app.fqdn).then(function () {
return pageLoaded();
return waitForElement(By.xpath('//span[text()="Actions"]'));
}).then(function() {
return browser.findElement(by.css('#folders button')).click();
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();
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();
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();
return browser.findElement(By.css('[ng-click*=deleteFolder]')).click();
}).then(function () {
return browser.sleep(3000); //This needs to run for some time
}).then(function () {
@@ -141,54 +134,64 @@ describe('Application life cycle test', function () {
});
}
function wait (done) {
setTimeout(done, 10000);
}
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); });
it('can get app information', getAppInfo);
it('wait', wait);
it('fails with invalid password', invalidPassword);
it('can load page', loadPage);
it('can add folder', addFolder);
it('backup app', function () { execSync('cloudron backup create --app ' + app.id, EXEC_ARGS); });
it('restore app', function () { execSync('cloudron restore --app ' + app.id, EXEC_ARGS); });
it('restore app', async function () {
await browser.get('about:blank');
execSync('cloudron restore --app ' + app.id, EXEC_ARGS);
});
it('wait', wait);
it('can load page', loadPage);
it('can check folder', checkFolder);
it('move to different location', function (done) {
// ensure we don't hit NXDOMAIN in the mean time
browser.get('about:blank').then(function () {
execSync(`cloudron configure --location ${LOCATION}2 --app ${app.id}`, EXEC_ARGS);
done();
});
it('move to different location', async function () {
await browser.get('about:blank');
execSync(`cloudron configure --location ${LOCATION}2 --app ${app.id}`, EXEC_ARGS);
});
it('can get app information', getAppInfo);
it('wait', wait);
it('can load page', loadPage);
it('can check folder', checkFolder);
it('can remove folder', removeFolder);
it('uninstall app', function (done) {
browser.get('about:blank').then(function () {
execSync('cloudron uninstall --app ' + app.id, EXEC_ARGS);
done();
});
it('uninstall app', async function () {
await browser.get('about:blank');
execSync('cloudron uninstall --app ' + app.id, EXEC_ARGS);
});
// 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 get app information', getAppInfo);
it('wait', wait);
it('can load page', loadPage);
it('can add folder', addFolder);
it('can update', function () { execSync('cloudron update --app ' + LOCATION, EXEC_ARGS); });
it('wait for app to startup fully', function (done) { setTimeout(done, 10000); });
it('can update', async function () {
await browser.get('about:blank');
execSync('cloudron update --app ' + LOCATION, EXEC_ARGS);
});
it('wait', wait);
it('can check folder', checkFolder);
it('uninstall app', function (done) {
browser.get('about:blank').then(function () {
execSync('cloudron uninstall --app ' + app.id, EXEC_ARGS);
done();
});
it('uninstall app', async function () {
await browser.get('about:blank');
execSync('cloudron uninstall --app ' + app.id, EXEC_ARGS);
});
});