summaryrefslogtreecommitdiffstats
path: root/test/utils
diff options
context:
space:
mode:
authorARULNA <arul.nambi@amdocs.com>2017-06-02 16:27:25 -0400
committerARULNA <arul.nambi@amdocs.com>2017-06-02 16:33:14 -0400
commitca007e933bcd9f63aa77801656ed9dd4142c432c (patch)
treece97ed9df8c4fe48a524f0dc1365ad28acef7c46 /test/utils
parent42b788b852f0604748828e9e325e4a0f01152c75 (diff)
Initial coomit for AAI-UI(sparky-fe)
Change-Id: I9f8482824a52bac431c100939899e760c0fa4fdb Signed-off-by: ARULNA <arul.nambi@amdocs.com>
Diffstat (limited to 'test/utils')
-rw-r--r--test/utils/MockRest.js90
1 files changed, 90 insertions, 0 deletions
diff --git a/test/utils/MockRest.js b/test/utils/MockRest.js
new file mode 100644
index 0000000..f40b120
--- /dev/null
+++ b/test/utils/MockRest.js
@@ -0,0 +1,90 @@
+/*
+ * ============LICENSE_START=======================================================
+ * SPARKY (AAI UI service)
+ * ================================================================================
+ * Copyright © 2017 AT&T Intellectual Property.
+ * Copyright © 2017 Amdocs
+ * All rights reserved.
+ * ================================================================================
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ * ============LICENSE_END=========================================================
+ *
+ * ECOMP and OpenECOMP are trademarks
+ * and service marks of AT&T Intellectual Property.
+ */
+
+const queue = {
+ fetch: [],
+ put: [],
+ post: [],
+ destroy: []
+};
+
+const initQueue = () => {
+ queue['fetch'] = [];
+ queue['put'] = [];
+ queue['post'] = [];
+ queue['destroy'] = [];
+};
+
+const handleOperation = (handler, options) => {
+ if(typeof handler === 'function') {
+ return Promise.resolve(handler(options));
+ }
+ else {
+ return Promise.resolve(handler);
+ }
+};
+
+export default {
+
+ fetch(baseUrl, options) {
+ const {fetch} = queue;
+ if(!fetch.length) {
+ throw new Error(`Fetch operation was called without proper handler. baseUrl: '${baseUrl}' options: '${options}'`);
+ }
+ return handleOperation(fetch.shift(), {options, baseUrl});
+ },
+
+ put(baseUrl, data, options) {
+ const {put} = queue;
+ if(!put.length) {
+ throw new Error(`put operation was called without proper handler. baseUrl: '${baseUrl}' options: '${options}'`);
+ }
+ return handleOperation(put.shift(), {data, options, baseUrl});
+ },
+
+ post(baseUrl, data, options) {
+ const {post} = queue;
+ if(!post.length) {
+ throw new Error(`post operation was called without proper handler. baseUrl: '${baseUrl}' options: '${options}'`);
+ }
+ return handleOperation(post.shift(), {data, options, baseUrl});
+ },
+
+ destroy(baseUrl, options) {
+ const {destroy} = queue;
+ if(!destroy.length) {
+ throw new Error(`Destroy operation was called without proper handler. baseUrl: '${baseUrl}' options: '${options}'`);
+ }
+ return handleOperation(destroy.shift(), {options, baseUrl});
+ },
+
+ addHandler(operation, handler) {
+ queue[operation].push(handler);
+ },
+
+ resetQueue() {
+ initQueue();
+ }
+};