Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Release #2416

Merged
merged 111 commits into from
Jan 4, 2021
Merged

Release #2416

Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
111 commits
Select commit Hold shift + click to select a range
bf5693f
Reset table selected row when table data changes (#2307)
vicky-primathon Dec 23, 2020
6b6e302
Fix Table data validation issues (#2297)
vicky-primathon Dec 23, 2020
0bcc887
reorder widget locale wise, autofocus search input
rishabhsaxena Dec 23, 2020
61e1223
Revert "reorder widget locale wise, autofocus search input"
rishabhsaxena Dec 23, 2020
c7f330c
Missing isEncrypted should mean a true value
sharat87 Dec 23, 2020
d5e0fb1
Add migration to set isEncrypted field where missing (#2332)
sharat87 Dec 23, 2020
9417335
render column submenu popover inline (#2329)
rishabhsaxena Dec 23, 2020
77801b1
fix undo delete tab, create copy of tabs array (#2315)
rishabhsaxena Dec 23, 2020
778b82f
enable hotkeys only when a widget is selected (#2262)
rishabhsaxena Dec 23, 2020
fb7ae53
set the first tab as selected when the selected tab is not found (#2231)
rishabhsaxena Dec 23, 2020
396b12b
reorder widgets alphabetically, autofocus search input (#2325)
rishabhsaxena Dec 23, 2020
4e802d2
reset query on select, don't jump to active item (#2237)
rishabhsaxena Dec 23, 2020
3930c4c
Hotfix circularJSON (#2214)
ofpiyush Dec 23, 2020
806a139
Make prettier changes (#2337)
ofpiyush Dec 24, 2020
83349e2
fix modal entity not renamed through property pane when closed by cli…
rishabhsaxena Dec 24, 2020
466d0cf
Fix explorer entity icon alignment (#1413)
akash-codemonk Dec 24, 2020
8ef8bfd
Prettier fix. (#2353)
ofpiyush Dec 24, 2020
ebcffad
Prettier fixes (#2366)
ofpiyush Dec 28, 2020
6210b9a
All newly created applications now have a default published state. (#…
trishaanand Dec 28, 2020
45497ba
Bump node-notifier from 8.0.0 to 8.0.1 in /app/client (#2316)
dependabot[bot] Dec 28, 2020
6299c86
Add TC to test mongodb connection establishment (#2364)
sumitsum Dec 28, 2020
988ebe9
RPC-like layer with graceful startup and shutdown around a webworker …
ofpiyush Dec 28, 2020
051d3c6
Adding leak detection to hikari pool. Would be tracking this on logdn…
trishaanand Dec 28, 2020
ea2244e
Update README.md
Nikhil-Nandagopal Dec 29, 2020
a48242b
Create project-labeler.yml
Nikhil-Nandagopal Dec 29, 2020
9bbf8db
Create project-labeler.yml
Nikhil-Nandagopal Dec 29, 2020
de5c112
Update project-labeler.yml
Nikhil-Nandagopal Dec 29, 2020
04fbf3c
Update project-labeler.yml
Nikhil-Nandagopal Dec 29, 2020
651b5c4
Update project-labeler.yml
Nikhil-Nandagopal Dec 29, 2020
15af387
Update project-labeler.yml
Nikhil-Nandagopal Dec 29, 2020
ddc9c0c
Update project-labeler.yml
Nikhil-Nandagopal Dec 29, 2020
f0d4a23
Create super-labeler.yml
Nikhil-Nandagopal Dec 29, 2020
407b10c
Create config.json
Nikhil-Nandagopal Dec 29, 2020
a58a3c3
Update config.json
Nikhil-Nandagopal Dec 29, 2020
f9f6bcd
Rename super-labeler.yml to main.yml
Nikhil-Nandagopal Dec 29, 2020
4929608
Update main.yml
Nikhil-Nandagopal Dec 29, 2020
134f1a9
Plugin code contribution guidelines file. (#2324)
sumitsum Dec 29, 2020
f0f1577
Update main.yml
Nikhil-Nandagopal Dec 29, 2020
ea0f9c1
[Bug] Multi page applications return only a single page when fetching…
trishaanand Dec 29, 2020
fd1ae6b
Update main.yml
Nikhil-Nandagopal Dec 29, 2020
ee1cce9
Update main.yml
Nikhil-Nandagopal Dec 29, 2020
49c1724
Update main.yml
Nikhil-Nandagopal Dec 29, 2020
e56e7db
Update main.yml
Nikhil-Nandagopal Dec 29, 2020
178710d
Update config.json
Nikhil-Nandagopal Dec 29, 2020
f63fe63
Update config.json
Nikhil-Nandagopal Dec 29, 2020
592121a
Update config.json
Nikhil-Nandagopal Dec 29, 2020
9de7dd6
Update main.yml
Nikhil-Nandagopal Dec 29, 2020
0930be6
Update main.yml
Nikhil-Nandagopal Dec 29, 2020
0c44e94
Update config.json
Nikhil-Nandagopal Dec 29, 2020
a149295
Update main.yml
Nikhil-Nandagopal Dec 29, 2020
14a12c3
Update config.json
Nikhil-Nandagopal Dec 29, 2020
2bcad75
Update config.json
Nikhil-Nandagopal Dec 29, 2020
3d16a93
Update config.json
Nikhil-Nandagopal Dec 29, 2020
90c5707
Update config.json
Nikhil-Nandagopal Dec 29, 2020
e123060
Update main.yml
Nikhil-Nandagopal Dec 29, 2020
b5e8673
Properly log data tree instrumentation (#2228)
hetunandu Dec 29, 2020
bfa8860
Update config.json
Nikhil-Nandagopal Dec 29, 2020
6fc2732
Update config.json
Nikhil-Nandagopal Dec 29, 2020
4e2e53e
Update config.json
Nikhil-Nandagopal Dec 29, 2020
2f30916
Update config.json
Nikhil-Nandagopal Dec 29, 2020
4b13fd0
Update config.json
Nikhil-Nandagopal Dec 29, 2020
57ec3d6
Create label-commands.yml
Nikhil-Nandagopal Dec 29, 2020
f5472fe
Create label-commands.yml
Nikhil-Nandagopal Dec 29, 2020
e9fd76b
Update label-commands.yml
Nikhil-Nandagopal Dec 29, 2020
561a89f
Update label-commands.yml
Nikhil-Nandagopal Dec 29, 2020
b9b30dd
Update label-commands.yml
Nikhil-Nandagopal Dec 29, 2020
a7319fc
Update label-commands.yml
Nikhil-Nandagopal Dec 29, 2020
338eb5c
Update label-commands.yml
Nikhil-Nandagopal Dec 29, 2020
43491c8
Update label-commands.yml
Nikhil-Nandagopal Dec 29, 2020
b0d1350
Update main.yml
Nikhil-Nandagopal Dec 29, 2020
8d8284c
Update label-commands.yml
Nikhil-Nandagopal Dec 29, 2020
0a23fb9
Delete main.yml
Nikhil-Nandagopal Dec 29, 2020
20d3c62
Update label-commands.yml
Nikhil-Nandagopal Dec 29, 2020
2e85d8c
Update label-commands.yml
Nikhil-Nandagopal Dec 29, 2020
e2db152
Update label-commands.yml
Nikhil-Nandagopal Dec 29, 2020
7cd2f89
Update label-commands.yml
Nikhil-Nandagopal Dec 29, 2020
eb6dcc0
Update label-commands.yml
Nikhil-Nandagopal Dec 29, 2020
85e896d
Update label-commands.yml
Nikhil-Nandagopal Dec 29, 2020
e526f5c
minox css fixes (#2375)
rishabhsaxena Dec 29, 2020
4c4d0b7
Update label-commands.yml
Nikhil-Nandagopal Dec 29, 2020
735a439
Added a migration to old rest api datasources which adds the new mand…
trishaanand Dec 29, 2020
d77ad4b
Update label-commands.yml
Nikhil-Nandagopal Dec 29, 2020
c9c1f4d
Update label-commands.yml
Nikhil-Nandagopal Dec 29, 2020
40026cf
Update label-commands.yml
Nikhil-Nandagopal Dec 29, 2020
ea366b1
Fixed NPE in database migration
trishaanand Dec 29, 2020
13fae1a
fix test (#2390)
rishabhsaxena Dec 29, 2020
712f41d
Reducing the probability of getting pages out of order (Expected orde…
trishaanand Dec 29, 2020
ccd9371
update tooltip test (#2392)
rishabhsaxena Dec 29, 2020
14effe6
fix del hotkey (#2349)
rishabhsaxena Dec 29, 2020
37d0314
default error code (#2363)
rishabhsaxena Dec 29, 2020
5ae2da1
Send clean validated tree back (#2376)
ofpiyush Dec 29, 2020
1a35bb1
Onboarding flow (#2311)
akash-codemonk Dec 30, 2020
f1f9441
auto focus search input (#2360)
rishabhsaxena Dec 30, 2020
6dd97a6
fix stacking order of popover and app header (#2338)
rishabhsaxena Dec 30, 2020
4d24217
Update project-labeler.yml
Nikhil-Nandagopal Dec 30, 2020
d4640e0
Invite users once triggered should not be cancellable. (#2401)
trishaanand Dec 30, 2020
31d8c8c
[Worker] Fix critical issues (#2393)
hetunandu Dec 30, 2020
c344377
only autofocus widget search (#2400)
rishabhsaxena Dec 30, 2020
611186c
set min pageSize for table widget (#2362)
rishabhsaxena Dec 30, 2020
3d7242d
Cleanup cancelled requests (#2387)
ofpiyush Dec 30, 2020
9d0c6d5
fix datetimepicker max date issue (#2407)
jsartisan Dec 31, 2020
a337839
Increasing pool size to 20 to reduce the number of times datasource b…
trishaanand Dec 31, 2020
e17da5f
Merge branch 'release' of https://github.com/appsmithorg/appsmith int…
trishaanand Dec 31, 2020
24ef325
Merge branch 'master' into release
trishaanand Jan 4, 2021
214f911
Fixed merge conflict related build failure.
trishaanand Jan 4, 2021
4c5387f
updated assertion (#2419)
NandanAnantharamu Jan 4, 2021
74c4971
Update and rename label-commands.yml to main.yml
Nikhil-Nandagopal Jan 4, 2021
7bd70ee
Update config.json
Nikhil-Nandagopal Jan 4, 2021
2f7c233
Delete label-commands.yml
Nikhil-Nandagopal Jan 4, 2021
62656d7
Update config.json
Nikhil-Nandagopal Jan 4, 2021
bb81d35
Update config.json
Nikhil-Nandagopal Jan 4, 2021
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
Prev Previous commit
Next Next commit
Cleanup cancelled requests (#2387)
  • Loading branch information
ofpiyush authored Dec 30, 2020
commit 3d7242d7169623d480fbfef983848fc4cf7ac25d
109 changes: 83 additions & 26 deletions app/client/src/sagas/evaluationsSaga.ts
Original file line number Diff line number Diff line change
@@ -1,12 +1,4 @@
import {
all,
call,
fork,
put,
select,
take,
takeLatest,
} from "redux-saga/effects";
import { actionChannel, call, put, select, take } from "redux-saga/effects";

import {
EvaluationReduxAction,
Expand Down Expand Up @@ -37,6 +29,7 @@ import { Variant } from "components/ads/common";
import { Toaster } from "components/ads/Toast";
import * as Sentry from "@sentry/react";
import { EXECUTION_PARAM_KEY } from "../constants/ActionConstants";
import { Action } from "redux";

let widgetTypeConfigMap: WidgetTypeConfigMap;

Expand Down Expand Up @@ -187,7 +180,14 @@ export function* validateProperty(
});
}

const FIRST_EVAL_REDUX_ACTIONS = [
// Pages
ReduxActionTypes.FETCH_PAGE_SUCCESS,
ReduxActionTypes.FETCH_PUBLISHED_PAGE_SUCCESS,
];

const EVALUATE_REDUX_ACTIONS = [
...FIRST_EVAL_REDUX_ACTIONS,
// Actions
ReduxActionTypes.FETCH_ACTIONS_SUCCESS,
ReduxActionTypes.FETCH_ACTIONS_VIEW_MODE_SUCCESS,
Expand Down Expand Up @@ -218,21 +218,42 @@ const EVALUATE_REDUX_ACTIONS = [
// Widget Meta
ReduxActionTypes.SET_META_PROP,
ReduxActionTypes.RESET_WIDGET_META,
// Pages
ReduxActionTypes.FETCH_PAGE_SUCCESS,
ReduxActionTypes.FETCH_PUBLISHED_PAGE_SUCCESS,
// Batches
ReduxActionTypes.BATCH_UPDATES_SUCCESS,
];

function* evaluationChangeListenerSaga() {
yield fork(worker.start);
widgetTypeConfigMap = WidgetFactory.getWidgetTypeConfigMap();
yield fork(evaluateTreeSaga);
while (true) {
const action: EvaluationReduxAction<unknown | unknown[]> = yield take(
EVALUATE_REDUX_ACTIONS,
);
function evalQueueBuffer() {
let initialised = false;
let takable = false;
let postEvalActions: any = [];
const take = () => {
if (takable) {
const resp = postEvalActions;
postEvalActions = [];
takable = false;
return { postEvalActions: resp, type: "FAKE_ACTION" };
}
};
const flush = () => {
if (takable) {
return [take() as Action];
}

return [];
};

const put = (action: EvaluationReduxAction<unknown | unknown[]>) => {
if (!initialised) {
if (
![
ReduxActionTypes.FETCH_PAGE_SUCCESS,
ReduxActionTypes.FETCH_PUBLISHED_PAGE_SUCCESS,
].includes(action.type)
) {
return;
}
initialised = true;
}
// When batching success action happens, we need to only evaluate
// if the batch had any action we need to evaluate properties for
if (
Expand All @@ -245,17 +266,53 @@ function* evaluationChangeListenerSaga() {
if (
_.intersection(EVALUATE_REDUX_ACTIONS, batchedActionTypes).length === 0
) {
continue;
return;
}
}
log.debug(`Evaluating`, { action });
yield fork(evaluateTreeSaga, action.postEvalActions);

takable = true;
// TODO: If the action is the same as before, we can send only one and ignore duplicates.
if (action.postEvalActions) {
postEvalActions.push(...action.postEvalActions);
}
};

return {
take,
put,
isEmpty: () => {
return !takable;
},
flush,
};
}

function* evaluationChangeListenerSaga() {
// Explicitly shutdown old worker if present
yield call(worker.shutdown);
yield call(worker.start);
widgetTypeConfigMap = WidgetFactory.getWidgetTypeConfigMap();
const evtActionChannel = yield actionChannel(
EVALUATE_REDUX_ACTIONS,
evalQueueBuffer(),
);
while (true) {
const action: EvaluationReduxAction<unknown | unknown[]> = yield take(
evtActionChannel,
);
yield call(evaluateTreeSaga, action.postEvalActions);
}
// TODO(hetu) need an action to stop listening and evaluate (exit app)
}

export default function* evaluationSagaListeners() {
yield all([
takeLatest(ReduxActionTypes.START_EVALUATION, evaluationChangeListenerSaga),
]);
yield take(ReduxActionTypes.START_EVALUATION);
while (true) {
try {
yield call(evaluationChangeListenerSaga);
} catch (e) {
log.error(e);
Sentry.captureException(e);
}
}
}
47 changes: 44 additions & 3 deletions app/client/src/utils/WorkerUtil.test.ts
Original file line number Diff line number Diff line change
@@ -1,8 +1,15 @@
import { GracefulWorkerService } from "./WorkerUtil";
import { runSaga } from "redux-saga";
import WebpackWorker from "worker-loader!";

const MessageType = "message";
class MockWorker {
class MockWorker implements WebpackWorker {
// Implement interface
onmessage: any;
onmessageerror: any;
dispatchEvent: any;
onerror: any;

callback: CallableFunction;
noop: CallableFunction;
messages: Array<any>;
Expand All @@ -26,12 +33,12 @@ class MockWorker {
this.running = true;
}

addEventListener(msgType: string, callback: CallableFunction) {
addEventListener(msgType: string, callback: any) {
expect(msgType).toEqual(MessageType);
this.callback = callback;
}

removeEventListener(msgType: string, callback: CallableFunction) {
removeEventListener(msgType: string, callback: any) {
expect(msgType).toEqual(MessageType);
expect(callback).toEqual(this.callback);
this.callback = this.noop;
Expand Down Expand Up @@ -168,4 +175,38 @@ describe("GracefulWorkerService", () => {
// The new worker should get the correct message
expect(await result2.toPromise()).toEqual(message2);
});

test("Cancelling saga before starting up should not crash", async () => {
const w = new GracefulWorkerService(MockWorker);
const message = { tree: "hello" };

const task = await runSaga({}, w.request, "cancel_test", message);
// Start shutting down
const shutdown = await runSaga({}, w.shutdown);
task.cancel();
// wait for shutdown
await shutdown.toPromise();
expect(await task.toPromise()).not.toEqual(message);
});

test("Cancelled saga should clean up", async () => {
const w = new GracefulWorkerService(MockWorker);
const message = { tree: "hello" };
await runSaga({}, w.start);

// Need this to work with eslint
if (MockWorker.instance === undefined) {
expect(MockWorker.instance).toBeDefined();
return;
}
// Make sure we get a chance to cancel before the worker can respond
MockWorker.instance.delayMilliSeconds = 100;
const task = await runSaga({}, w.request, "cancel_test", message);
// Start shutting down
const shutdown = await runSaga({}, w.shutdown);
task.cancel();
// wait for shutdown
await shutdown.toPromise();
expect(await task.toPromise()).not.toEqual(message);
});
});
Loading