Merge "Check if file has already been published"
diff --git a/test/mocks/datafilecollector-testharness/dr-sim/dmaapDR.js b/test/mocks/datafilecollector-testharness/dr-sim/dmaapDR.js
index 7e57b61..4e73174 100644
--- a/test/mocks/datafilecollector-testharness/dr-sim/dmaapDR.js
+++ b/test/mocks/datafilecollector-testharness/dr-sim/dmaapDR.js
@@ -4,12 +4,13 @@
var express = require('express');
const stream = require('stream');
var app = express();
-var fs = require("fs");
+var fs = require('fs');
var path = require('path');
var privateKey = fs.readFileSync('cert/private.key', 'utf8');
var certificate = fs.readFileSync('cert/certificate.crt', 'utf8');
var credentials = {key: privateKey, cert: certificate};
-
+const allPublished = "allPublished";
+const nonePublished = "nonePublished";
var parser = new ArgumentParser({
version: '0.0.1',
@@ -27,22 +28,18 @@
var args = parser.parseArgs();
-if (args.tc=="100") {
- console.log("TC: 100")
+if (args.tc=="nonePublished") {
+ console.log("TC: nonePublished")
}
-if (args.tc=="101") {
- console.log("TC: 101")
- //preparations
-}
-if (args.tc=="102") {
- console.log("TC: 102")
+if (args.tc=="allPublished") {
+ console.log("TC: allPublished")
//preparations
}
if (args.printtc) {
- console.log("TC 100: receive all incoming files");
- console.log("TC 101: drop/deny first 10 publishing attempt, then receive all");
- console.log("TC 102: drop/deny/every second publisging attempt");
+ console.log("TC nonePublished: no file has already been published.");
+ console.log("TC allPublished: whatever is the request, this file is considered as published.");
+ console.log("No argument passed: normal behaviour, that is publish if not already published");
process.exit(0);
}
@@ -62,19 +59,55 @@
app.get("/",function(req, res){
res.send("ok");
})
-app.put('/publish/1/:filename', function (req, res) {
- console.log(req.files);
- console.log(req.body);
- console.log(req.headers);
- var filename = path.basename(req.params.filename);
- res.redirect(301, 'http://127.0.0.1:3908/publish/1/'+filename)
+
+
+var published = [];
+app.get('/feedlog/1/',function(req, res){
+ var filename = req.query.filename;
+ if(args.tc == allPublished){
+ res.send("[" + filename + "]");
+ } else if(args.tc == nonePublished){
+ res.send("[]");
+ } else {
+ if (published.includes(filename)) {
+ res.send("[" + filename + "]");
+ } else {
+ res.send("[]");
+ }
+ }
})
+
+
+app.put('/publish/1/', function (req, res) {
+ var filename = req.query.filename;
+ var type = req.query.type;
+ if(typeof(filename) == 'undefined'){
+ res.status(400).send({error: 'No filename provided.'});
+ } else if(typeof(type) == 'undefined'){
+ res.status(400).send({error: 'No type provided.'});
+ } else {
+ if(args.tc == allPublished){
+ res.send("[" + filename + "]");
+ } else if(args.tc == nonePublished){
+ res.redirect(301, 'http://127.0.0.1:3908/publish/1/'+filename);
+ } else {
+ if (!published.includes(filename)) {
+ published.push(filename);
+ res.redirect(301, 'http://127.0.0.1:3908/publish/1/'+filename);
+ } else {
+ res.send("ok");
+ }
+ }
+ }
+})
+
+
var httpServer = http.createServer(app);
var httpsServer = https.createServer(credentials, app);
-var httpPort=3906
-var httpsPort=3907
+var httpPort=3906;
+var httpsPort=3907;
httpServer.listen(httpPort);
-console.log("DR-simulator listening (http) at "+httpPort)
+console.log("DR-simulator listening (http) at "+httpPort);
httpsServer.listen(httpsPort);
-console.log("DR-simulator listening (https) at "+httpsPort)
+console.log("DR-simulator listening (https) at "+httpsPort);
\ No newline at end of file