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

Compare commits

..

13 Commits

Author SHA1 Message Date
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
6 changed files with 652 additions and 217 deletions

View File

@@ -444,3 +444,29 @@
* #9274: Missing lock in DeviceStatistics ("fatal error: concurrent map read and map write") * #9274: Missing lock in DeviceStatistics ("fatal error: concurrent map read and map write")
* #7406: Add UPnP support for IPv6 * #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)

View File

@@ -5,8 +5,8 @@
"description": "file://DESCRIPTION.md", "description": "file://DESCRIPTION.md",
"changelog": "file://CHANGELOG", "changelog": "file://CHANGELOG",
"tagline": "Decentralized file synchronization", "tagline": "Decentralized file synchronization",
"version": "1.26.1", "version": "1.26.5",
"upstreamVersion": "1.27.2", "upstreamVersion": "1.27.6",
"healthCheckPath": "/healthcheck", "healthCheckPath": "/healthcheck",
"httpPort": 8000, "httpPort": 8000,
"addons": { "addons": {

View File

@@ -3,7 +3,7 @@ FROM cloudron/base:4.2.0@sha256:46da2fffb36353ef714f97ae8e962bd2c212ca091108d768
RUN mkdir -p /app/code RUN mkdir -p /app/code
WORKDIR /app/code WORKDIR /app/code
ARG VERSION=1.27.2 ARG VERSION=1.27.6
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 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

808
test/package-lock.json generated

File diff suppressed because it is too large Load Diff

View File

@@ -9,10 +9,10 @@
"author": "", "author": "",
"license": "ISC", "license": "ISC",
"dependencies": { "dependencies": {
"chromedriver": "^120.0.1", "chromedriver": "^123.0.2",
"expect.js": "^0.3.1", "expect.js": "^0.3.1",
"mocha": "^10.2.0", "mocha": "^10.4.0",
"selenium-webdriver": "^4.16.0", "selenium-webdriver": "^4.19.0",
"superagent": "^8.1.2" "superagent": "^8.1.2"
} }
} }

View File

@@ -67,6 +67,17 @@ describe('Application life cycle test', function () {
await waitForElement(By.xpath('//span[text()="Actions"]')); await waitForElement(By.xpath('//span[text()="Actions"]'));
} }
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'));
}
async function loadPage() { async function loadPage() {
await browser.get('https://' + app.fqdn); await browser.get('https://' + app.fqdn);
await waitForElement(By.xpath('//span[text()="Actions"]')); await waitForElement(By.xpath('//span[text()="Actions"]'));
@@ -76,12 +87,13 @@ describe('Application life cycle test', function () {
await browser.get('https://' + app.fqdn); await browser.get('https://' + app.fqdn);
await browser.findElement(By.css('[ng-click*=addFolder]')).click(); await browser.findElement(By.css('[ng-click*=addFolder]')).click();
await waitForElement(By.id('folderPath')); await waitForElement(By.id('folderPath'));
await browser.sleep(4000); // wait more, not sure why this is needed await browser.sleep(8000); // wait more, not sure why this is needed
await browser.findElement(By.id('folderLabel')).sendKeys(FOLDER); await browser.findElement(By.id('folderLabel')).sendKeys(FOLDER);
await browser.sleep(4000); // without this sometimes only part of the folder name gets through 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.findElement(By.css('[ng-click*=saveFolder]')).click();
await browser.sleep(8000); // without this "stale element"
await waitForElement(By.xpath(`//span[contains(text(), '${FOLDER}')]`)); await waitForElement(By.xpath(`//span[contains(text(), '${FOLDER}')]`));
await browser.sleep(4000); await browser.sleep(8000);
} }
async function checkFolder() { async function checkFolder() {
@@ -114,6 +126,7 @@ describe('Application life cycle test', function () {
it('can login', login.bind(null, username, password)); it('can login', login.bind(null, username, password));
it('can load page', loadPage); it('can load page', loadPage);
it('can add folder', addFolder); it('can add folder', addFolder);
it('can logout', logout);
it('backup app', async function () { execSync('cloudron backup create --app ' + app.id, EXEC_ARGS); }); it('backup app', async function () { execSync('cloudron backup create --app ' + app.id, EXEC_ARGS); });
it('restore app', async function () { it('restore app', async function () {
@@ -125,6 +138,7 @@ describe('Application life cycle test', function () {
it('can login', login.bind(null, username, password)); it('can login', login.bind(null, username, password));
it('can load page', loadPage); it('can load page', loadPage);
it('can check folder', checkFolder); it('can check folder', checkFolder);
it('can logout', logout);
it('move to different location', async function () { it('move to different location', async function () {
await browser.get('about:blank'); await browser.get('about:blank');
@@ -136,6 +150,7 @@ describe('Application life cycle test', function () {
it('can login', login.bind(null, username, password)); it('can login', login.bind(null, username, password));
it('can load page', loadPage); it('can load page', loadPage);
it('can check folder', checkFolder); it('can check folder', checkFolder);
it('can logout', logout);
it('uninstall app', async function () { it('uninstall app', async function () {
await browser.get('about:blank'); await browser.get('about:blank');
@@ -151,6 +166,8 @@ describe('Application life cycle test', function () {
it('can login', login.bind(null, username, password)); it('can login', login.bind(null, username, password));
it('can load page', loadPage); it('can load page', loadPage);
it('can add folder', addFolder); it('can add folder', addFolder);
it('can logout', logout);
it('can update', async function () { it('can update', async function () {
await browser.get('about:blank'); await browser.get('about:blank');
execSync('cloudron update --app ' + LOCATION, EXEC_ARGS); execSync('cloudron update --app ' + LOCATION, EXEC_ARGS);