diff --git a/app.js b/app.js
index f0579b1dc..80e5b00a7 100644
--- a/app.js
+++ b/app.js
@@ -1,34 +1,47 @@
-var express = require('express');
-var path = require('path');
-var favicon = require('serve-favicon');
-var logger = require('morgan');
-var cookieParser = require('cookie-parser');
-var bodyParser = require('body-parser');
+var express = require('express')
+var path = require('path')
+var favicon = require('serve-favicon')
+var logger = require('morgan')
+var cookieParser = require('cookie-parser')
+var bodyParser = require('body-parser')
-var routes = require('./routes/index');
+var massive = require('massive')
+var connectionString = "postgres://localhost/video-store-api"
-var app = express();
+var app = module.exports = express()
+
+var db = massive.connectSync({connectionString : connectionString})
+app.set('db', db)
// view engine setup
-app.set('views', path.join(__dirname, 'views'));
-app.set('view engine', 'jade');
+app.set('views', path.join(__dirname, 'views'))
+app.set('view engine', 'jade')
+
+//views...?
+app.engine('html', require('ejs').renderFile)
+app.set('view engine', 'html')
+
+var routes = require('./routes/index')
+
+var zomgRoutes = require('./routes/zomg')
// uncomment after placing your favicon in /public
-//app.use(favicon(path.join(__dirname, 'public', 'favicon.ico')));
-app.use(logger('dev'));
-app.use(bodyParser.json());
-app.use(bodyParser.urlencoded({ extended: false }));
-app.use(cookieParser());
-app.use(express.static(path.join(__dirname, 'public')));
+//app.use(favicon(path.join(__dirname, 'public', 'favicon.ico')))
+app.use(logger('dev'))
+app.use(bodyParser.json())
+app.use(bodyParser.urlencoded({ extended: false }))
+app.use(cookieParser())
+app.use(express.static(path.join(__dirname, 'public')))
-app.use('/', routes);
+app.use('/', routes)
+app.use('/zomg', zomgRoutes)
// catch 404 and forward to error handler
app.use(function(req, res, next) {
- var err = new Error('Not Found');
- err.status = 404;
- next(err);
-});
+ var err = new Error('Not Found')
+ err.status = 404
+ next(err)
+})
// error handlers
@@ -36,23 +49,20 @@ app.use(function(req, res, next) {
// will print stacktrace
if (app.get('env') === 'development') {
app.use(function(err, req, res, next) {
- res.status(err.status || 500);
+ res.status(err.status || 500)
res.render('error', {
message: err.message,
error: err
- });
- });
+ })
+ })
}
// production error handler
// no stacktraces leaked to user
app.use(function(err, req, res, next) {
- res.status(err.status || 500);
+ res.status(err.status || 500)
res.render('error', {
message: err.message,
error: {}
- });
-});
-
-
-module.exports = app;
+ })
+})
diff --git a/controllers/customers_controller.js b/controllers/customers_controller.js
new file mode 100644
index 000000000..9f37e43fe
--- /dev/null
+++ b/controllers/customers_controller.js
@@ -0,0 +1,55 @@
+var Customer = require("../models/customer")
+var Rental = require("../models/rental")
+
+var CustomersController = {
+
+ index: function(req, res, next) {
+ Customer.all(function(error, customers) {
+ if(error) {
+ var err = new Error("Error retrieving customers:\n" + error.message)
+ err.status = 500
+ next(err)
+ } else {
+ res.json(customers)
+ }
+ })
+ },
+
+ sort: function(req, res, next) {
+ Customer.sort(req.params.column_name, req.params.columns, req.query.n, req.query.p, function(error, customers) {
+ if(error) {
+ var err = new Error("Error retrieving customers:\n" + error.message)
+ err.status = 500
+ next(err)
+ } else {
+ res.json(customers)
+ }
+ })
+ },
+
+ current: function(req, res, next) {
+ Rental.current_id(req.params.id, req.params.column_name, function(error, rentals) {
+ if(error) {
+ var err = new Error("Error retrieving rentals" + error.message)
+ err.status = 500
+ next(err)
+ } else {
+ res.json(rentals)
+ }
+ })
+ },
+
+ history: function(req, res, next) {
+ Rental.history_cust_id(req.params.id, req.params.column_name, req.params.column, function(error, rentals) {
+ if(error) {
+ var err = new Error("Error retrieving rentals:\n" + error.message)
+ err.status = 500
+ next(err)
+ } else {
+ res.json(rentals)
+ }
+ })
+ }
+}
+
+module.exports = CustomersController
diff --git a/controllers/movies_controller.js b/controllers/movies_controller.js
new file mode 100644
index 000000000..17ee9fc4c
--- /dev/null
+++ b/controllers/movies_controller.js
@@ -0,0 +1,55 @@
+var Movie = require("../models/movie")
+var Rental = require("../models/rental")
+
+var MoviesController = {
+
+ index: function(req, res, next) {
+ Movie.all(function(error, movies) {
+ if(error) {
+ var err = new Error("Error retrieving movies:\n" + error.message)
+ err.status = 500
+ next(err)
+ } else {
+ res.json(movies)
+ }
+ })
+ },
+
+ sort: function(req, res, next) {
+ Movie.sort(req.params.column_name, req.query.n, req.query.p, function(error, movies) {
+ if(error) {
+ var err = new Error("Error retrieving movies:\n" + error.message)
+ err.status = 500
+ next(err)
+ } else {
+ res.json(movies)
+ }
+ })
+ },
+
+ current: function(req, res, next) {
+ Rental.current_title(req.params.title, req.params.columns, function(error, rentals) {
+ if(error) {
+ var err = new Error("Error retrieving rentals:\n" + error.message)
+ err.status = 500
+ next(err)
+ } else {
+ res.json(rentals)
+ }
+ })
+ },
+
+ history: function(req, res, next) {
+ Rental.history_title(req.params.title, req.params.column_name, function(error, rentals) {
+ if(error) {
+ var err = new Error("Error retrieving rentals:\n" + error.message)
+ err.status = 500
+ next(err)
+ } else {
+ res.json(rentals)
+ }
+ })
+ }
+}
+
+module.exports = MoviesController
diff --git a/controllers/rentals_controller.js b/controllers/rentals_controller.js
new file mode 100644
index 000000000..829b9ad8c
--- /dev/null
+++ b/controllers/rentals_controller.js
@@ -0,0 +1,62 @@
+var Rental = require("../models/rental")
+var Movie = require("../models/movie")
+var Customer = require("../models/customer")
+
+var RentalsController = {
+ view: function(req, res, next) {
+ Rental.view(req.params.title, function(error, movies) {
+ if(error) {
+ var err = new Error("Error retrieving movies:\n" + error.message)
+ err.status = 500
+ next(err)
+ } else {
+ res.json(movies)
+ }
+ })
+ },
+
+ customers: function(req, res, next) {
+ Rental.customers(req.params.title, function(error, customers) {
+ if(error) {
+ var err = new Error("Error retrieving customers:\n" + error.message)
+ err.status = 500
+ next(err)
+ } else {
+ res.json(customers)
+ }
+ })
+ },
+
+ check_out: function(req, res) {
+ var title = req.params.title
+ var customer_id = req.params.customer_id
+
+ Rental.check_out(title, customer_id, function(error, result, next) {
+ if(error) {
+ var err = new Error("Error completing rental:\n" + error.message)
+ err.status = 500
+ next(err)
+ } else {
+ res.json(result)
+ res.statusCode = 204
+ }
+ })
+ },
+
+ return_rental: function(req, res) {
+ console.log("request: " + res)
+
+ Rental.return_rental(title, customer_id, function(error, result, next) {
+ if(error) {
+ var err = new Error("Error completing rental:\n" + error.message)
+ err.status = 500
+ next(err)
+ } else {
+ res.json(result)
+ res.statusCode = 204
+ }
+ })
+ }
+}
+
+module.exports = RentalsController
diff --git a/coverage/coverage.json b/coverage/coverage.json
new file mode 100644
index 000000000..5336593d0
--- /dev/null
+++ b/coverage/coverage.json
@@ -0,0 +1 @@
+{"/Users/sakne/C5/projects/VideoStoreAPI/app.js":{"path":"/Users/sakne/C5/projects/VideoStoreAPI/app.js","s":{"1":1,"2":1,"3":1,"4":1,"5":1,"6":1,"7":1,"8":1,"9":1,"10":1,"11":1,"12":1,"13":1,"14":1,"15":1,"16":1,"17":1,"18":1,"19":1,"20":1,"21":1,"22":1,"23":1,"24":0,"25":0,"26":0,"27":1,"28":0,"29":0,"30":0,"31":1,"32":0,"33":0},"b":{"1":[0,1],"2":[0,0],"3":[0,0]},"f":{"1":0,"2":0,"3":0},"fnMap":{"1":{"name":"(anonymous_1)","line":36,"loc":{"start":{"line":36,"column":8},"end":{"line":36,"column":33}}},"2":{"name":"(anonymous_2)","line":47,"loc":{"start":{"line":47,"column":10},"end":{"line":47,"column":40}}},"3":{"name":"(anonymous_3)","line":58,"loc":{"start":{"line":58,"column":8},"end":{"line":58,"column":38}}}},"statementMap":{"1":{"start":{"line":1,"column":0},"end":{"line":1,"column":32}},"2":{"start":{"line":2,"column":0},"end":{"line":2,"column":26}},"3":{"start":{"line":3,"column":0},"end":{"line":3,"column":38}},"4":{"start":{"line":4,"column":0},"end":{"line":4,"column":30}},"5":{"start":{"line":5,"column":0},"end":{"line":5,"column":43}},"6":{"start":{"line":6,"column":0},"end":{"line":6,"column":39}},"7":{"start":{"line":8,"column":0},"end":{"line":8,"column":32}},"8":{"start":{"line":9,"column":0},"end":{"line":9,"column":61}},"9":{"start":{"line":11,"column":0},"end":{"line":11,"column":36}},"10":{"start":{"line":13,"column":0},"end":{"line":13,"column":67}},"11":{"start":{"line":14,"column":0},"end":{"line":14,"column":17}},"12":{"start":{"line":17,"column":0},"end":{"line":17,"column":47}},"13":{"start":{"line":18,"column":0},"end":{"line":18,"column":30}},"14":{"start":{"line":20,"column":0},"end":{"line":20,"column":38}},"15":{"start":{"line":22,"column":0},"end":{"line":22,"column":41}},"16":{"start":{"line":26,"column":0},"end":{"line":26,"column":22}},"17":{"start":{"line":27,"column":0},"end":{"line":27,"column":26}},"18":{"start":{"line":28,"column":0},"end":{"line":28,"column":51}},"19":{"start":{"line":29,"column":0},"end":{"line":29,"column":23}},"20":{"start":{"line":30,"column":0},"end":{"line":30,"column":55}},"21":{"start":{"line":32,"column":0},"end":{"line":32,"column":20}},"22":{"start":{"line":33,"column":0},"end":{"line":33,"column":28}},"23":{"start":{"line":36,"column":0},"end":{"line":40,"column":2}},"24":{"start":{"line":37,"column":2},"end":{"line":37,"column":34}},"25":{"start":{"line":38,"column":2},"end":{"line":38,"column":18}},"26":{"start":{"line":39,"column":2},"end":{"line":39,"column":11}},"27":{"start":{"line":46,"column":0},"end":{"line":54,"column":1}},"28":{"start":{"line":47,"column":2},"end":{"line":53,"column":4}},"29":{"start":{"line":48,"column":4},"end":{"line":48,"column":33}},"30":{"start":{"line":49,"column":4},"end":{"line":52,"column":6}},"31":{"start":{"line":58,"column":0},"end":{"line":64,"column":2}},"32":{"start":{"line":59,"column":2},"end":{"line":59,"column":31}},"33":{"start":{"line":60,"column":2},"end":{"line":63,"column":4}}},"branchMap":{"1":{"line":46,"type":"if","locations":[{"start":{"line":46,"column":0},"end":{"line":46,"column":0}},{"start":{"line":46,"column":0},"end":{"line":46,"column":0}}]},"2":{"line":48,"type":"binary-expr","locations":[{"start":{"line":48,"column":15},"end":{"line":48,"column":25}},{"start":{"line":48,"column":29},"end":{"line":48,"column":32}}]},"3":{"line":59,"type":"binary-expr","locations":[{"start":{"line":59,"column":13},"end":{"line":59,"column":23}},{"start":{"line":59,"column":27},"end":{"line":59,"column":30}}]}}},"/Users/sakne/C5/projects/VideoStoreAPI/routes/index.js":{"path":"/Users/sakne/C5/projects/VideoStoreAPI/routes/index.js","s":{"1":1,"2":1,"3":1,"4":1,"5":1,"6":1,"7":0,"8":1,"9":0,"10":1,"11":0,"12":1,"13":0,"14":1,"15":0,"16":1,"17":0,"18":1,"19":0,"20":1,"21":0,"22":1,"23":0,"24":1,"25":0,"26":1,"27":0,"28":1,"29":0,"30":1,"31":0,"32":1,"33":0,"34":1},"b":{},"f":{"1":0,"2":0,"3":0,"4":0,"5":0,"6":0,"7":0,"8":0,"9":0,"10":0,"11":0,"12":0,"13":0,"14":0},"fnMap":{"1":{"name":"(anonymous_1)","line":7,"loc":{"start":{"line":7,"column":16},"end":{"line":7,"column":41}}},"2":{"name":"(anonymous_2)","line":11,"loc":{"start":{"line":11,"column":22},"end":{"line":11,"column":47}}},"3":{"name":"(anonymous_3)","line":15,"loc":{"start":{"line":15,"column":40},"end":{"line":15,"column":65}}},"4":{"name":"(anonymous_4)","line":20,"loc":{"start":{"line":20,"column":0},"end":{"line":20,"column":25}}},"5":{"name":"(anonymous_5)","line":24,"loc":{"start":{"line":24,"column":54},"end":{"line":24,"column":78}}},"6":{"name":"(anonymous_6)","line":28,"loc":{"start":{"line":28,"column":25},"end":{"line":28,"column":49}}},"7":{"name":"(anonymous_7)","line":32,"loc":{"start":{"line":32,"column":43},"end":{"line":32,"column":68}}},"8":{"name":"(anonymous_8)","line":36,"loc":{"start":{"line":36,"column":37},"end":{"line":36,"column":61}}},"9":{"name":"(anonymous_9)","line":41,"loc":{"start":{"line":41,"column":0},"end":{"line":41,"column":25}}},"10":{"name":"(anonymous_10)","line":47,"loc":{"start":{"line":47,"column":0},"end":{"line":47,"column":25}}},"11":{"name":"(anonymous_11)","line":52,"loc":{"start":{"line":52,"column":0},"end":{"line":52,"column":25}}},"12":{"name":"(anonymous_12)","line":57,"loc":{"start":{"line":57,"column":0},"end":{"line":57,"column":25}}},"13":{"name":"(anonymous_13)","line":62,"loc":{"start":{"line":62,"column":0},"end":{"line":62,"column":25}}},"14":{"name":"(anonymous_14)","line":67,"loc":{"start":{"line":67,"column":0},"end":{"line":67,"column":25}}}},"statementMap":{"1":{"start":{"line":1,"column":0},"end":{"line":1,"column":32}},"2":{"start":{"line":2,"column":0},"end":{"line":2,"column":29}},"3":{"start":{"line":3,"column":0},"end":{"line":3,"column":67}},"4":{"start":{"line":4,"column":0},"end":{"line":4,"column":73}},"5":{"start":{"line":5,"column":0},"end":{"line":5,"column":69}},"6":{"start":{"line":7,"column":0},"end":{"line":9,"column":2}},"7":{"start":{"line":8,"column":2},"end":{"line":8,"column":47}},"8":{"start":{"line":11,"column":0},"end":{"line":13,"column":2}},"9":{"start":{"line":12,"column":2},"end":{"line":12,"column":41}},"10":{"start":{"line":15,"column":0},"end":{"line":17,"column":2}},"11":{"start":{"line":16,"column":2},"end":{"line":16,"column":40}},"12":{"start":{"line":19,"column":0},"end":{"line":22,"column":2}},"13":{"start":{"line":21,"column":2},"end":{"line":21,"column":43}},"14":{"start":{"line":24,"column":0},"end":{"line":26,"column":2}},"15":{"start":{"line":25,"column":2},"end":{"line":25,"column":43}},"16":{"start":{"line":28,"column":0},"end":{"line":30,"column":2}},"17":{"start":{"line":29,"column":2},"end":{"line":29,"column":44}},"18":{"start":{"line":32,"column":0},"end":{"line":34,"column":2}},"19":{"start":{"line":33,"column":2},"end":{"line":33,"column":43}},"20":{"start":{"line":36,"column":0},"end":{"line":38,"column":2}},"21":{"start":{"line":37,"column":2},"end":{"line":37,"column":46}},"22":{"start":{"line":40,"column":0},"end":{"line":43,"column":2}},"23":{"start":{"line":42,"column":2},"end":{"line":42,"column":46}},"24":{"start":{"line":46,"column":0},"end":{"line":49,"column":2}},"25":{"start":{"line":48,"column":2},"end":{"line":48,"column":41}},"26":{"start":{"line":51,"column":0},"end":{"line":54,"column":2}},"27":{"start":{"line":53,"column":2},"end":{"line":53,"column":46}},"28":{"start":{"line":56,"column":0},"end":{"line":59,"column":2}},"29":{"start":{"line":58,"column":2},"end":{"line":58,"column":46}},"30":{"start":{"line":61,"column":0},"end":{"line":64,"column":2}},"31":{"start":{"line":63,"column":2},"end":{"line":63,"column":43}},"32":{"start":{"line":66,"column":0},"end":{"line":69,"column":2}},"33":{"start":{"line":68,"column":2},"end":{"line":68,"column":44}},"34":{"start":{"line":73,"column":0},"end":{"line":73,"column":23}}},"branchMap":{}},"/Users/sakne/C5/projects/VideoStoreAPI/controllers/movies_controller.js":{"path":"/Users/sakne/C5/projects/VideoStoreAPI/controllers/movies_controller.js","s":{"1":1,"2":1,"3":1,"4":0,"5":0,"6":0,"7":0,"8":0,"9":0,"10":0,"11":0,"12":0,"13":0,"14":0,"15":0,"16":0,"17":0,"18":0,"19":0,"20":0,"21":0,"22":0,"23":0,"24":0,"25":0,"26":0,"27":0,"28":1},"b":{"1":[0,0],"2":[0,0],"3":[0,0],"4":[0,0]},"f":{"1":0,"2":0,"3":0,"4":0,"5":0,"6":0,"7":0,"8":0},"fnMap":{"1":{"name":"(anonymous_1)","line":6,"loc":{"start":{"line":6,"column":9},"end":{"line":6,"column":34}}},"2":{"name":"(anonymous_2)","line":7,"loc":{"start":{"line":7,"column":14},"end":{"line":7,"column":38}}},"3":{"name":"(anonymous_3)","line":18,"loc":{"start":{"line":18,"column":8},"end":{"line":18,"column":33}}},"4":{"name":"(anonymous_4)","line":19,"loc":{"start":{"line":19,"column":65},"end":{"line":19,"column":89}}},"5":{"name":"(anonymous_5)","line":30,"loc":{"start":{"line":30,"column":11},"end":{"line":30,"column":36}}},"6":{"name":"(anonymous_6)","line":31,"loc":{"start":{"line":31,"column":63},"end":{"line":31,"column":88}}},"7":{"name":"(anonymous_7)","line":42,"loc":{"start":{"line":42,"column":11},"end":{"line":42,"column":36}}},"8":{"name":"(anonymous_8)","line":43,"loc":{"start":{"line":43,"column":67},"end":{"line":43,"column":92}}}},"statementMap":{"1":{"start":{"line":1,"column":0},"end":{"line":1,"column":38}},"2":{"start":{"line":2,"column":0},"end":{"line":2,"column":40}},"3":{"start":{"line":4,"column":0},"end":{"line":53,"column":1}},"4":{"start":{"line":7,"column":4},"end":{"line":15,"column":6}},"5":{"start":{"line":8,"column":6},"end":{"line":14,"column":7}},"6":{"start":{"line":9,"column":8},"end":{"line":9,"column":73}},"7":{"start":{"line":10,"column":8},"end":{"line":10,"column":24}},"8":{"start":{"line":11,"column":8},"end":{"line":11,"column":17}},"9":{"start":{"line":13,"column":8},"end":{"line":13,"column":24}},"10":{"start":{"line":19,"column":4},"end":{"line":27,"column":6}},"11":{"start":{"line":20,"column":6},"end":{"line":26,"column":7}},"12":{"start":{"line":21,"column":8},"end":{"line":21,"column":73}},"13":{"start":{"line":22,"column":8},"end":{"line":22,"column":24}},"14":{"start":{"line":23,"column":8},"end":{"line":23,"column":17}},"15":{"start":{"line":25,"column":8},"end":{"line":25,"column":24}},"16":{"start":{"line":31,"column":4},"end":{"line":39,"column":6}},"17":{"start":{"line":32,"column":6},"end":{"line":38,"column":7}},"18":{"start":{"line":33,"column":8},"end":{"line":33,"column":74}},"19":{"start":{"line":34,"column":8},"end":{"line":34,"column":24}},"20":{"start":{"line":35,"column":8},"end":{"line":35,"column":17}},"21":{"start":{"line":37,"column":8},"end":{"line":37,"column":25}},"22":{"start":{"line":43,"column":4},"end":{"line":51,"column":6}},"23":{"start":{"line":44,"column":6},"end":{"line":50,"column":7}},"24":{"start":{"line":45,"column":8},"end":{"line":45,"column":74}},"25":{"start":{"line":46,"column":8},"end":{"line":46,"column":24}},"26":{"start":{"line":47,"column":8},"end":{"line":47,"column":17}},"27":{"start":{"line":49,"column":8},"end":{"line":49,"column":25}},"28":{"start":{"line":55,"column":0},"end":{"line":55,"column":33}}},"branchMap":{"1":{"line":8,"type":"if","locations":[{"start":{"line":8,"column":6},"end":{"line":8,"column":6}},{"start":{"line":8,"column":6},"end":{"line":8,"column":6}}]},"2":{"line":20,"type":"if","locations":[{"start":{"line":20,"column":6},"end":{"line":20,"column":6}},{"start":{"line":20,"column":6},"end":{"line":20,"column":6}}]},"3":{"line":32,"type":"if","locations":[{"start":{"line":32,"column":6},"end":{"line":32,"column":6}},{"start":{"line":32,"column":6},"end":{"line":32,"column":6}}]},"4":{"line":44,"type":"if","locations":[{"start":{"line":44,"column":6},"end":{"line":44,"column":6}},{"start":{"line":44,"column":6},"end":{"line":44,"column":6}}]}}},"/Users/sakne/C5/projects/VideoStoreAPI/models/movie.js":{"path":"/Users/sakne/C5/projects/VideoStoreAPI/models/movie.js","s":{"1":1,"2":1,"3":1,"4":0,"5":1,"6":0,"7":0,"8":0,"9":0,"10":0,"11":0,"12":0,"13":1,"14":0,"15":0,"16":0,"17":0,"18":0,"19":0,"20":0,"21":0,"22":1},"b":{"1":[0,0],"2":[0,0],"3":[0,0],"4":[0,0],"5":[0,0],"6":[0,0],"7":[0,0],"8":[0,0]},"f":{"1":0,"2":0,"3":0,"4":0,"5":0,"6":0,"7":0},"fnMap":{"1":{"name":"(anonymous_1)","line":4,"loc":{"start":{"line":4,"column":12},"end":{"line":4,"column":25}}},"2":{"name":"(anonymous_2)","line":8,"loc":{"start":{"line":8,"column":12},"end":{"line":8,"column":31}}},"3":{"name":"(anonymous_3)","line":9,"loc":{"start":{"line":9,"column":17},"end":{"line":9,"column":41}}},"4":{"name":"(anonymous_4)","line":15,"loc":{"start":{"line":15,"column":32},"end":{"line":15,"column":48}}},"5":{"name":"(anonymous_5)","line":22,"loc":{"start":{"line":22,"column":13},"end":{"line":22,"column":51}}},"6":{"name":"(anonymous_6)","line":29,"loc":{"start":{"line":29,"column":30},"end":{"line":29,"column":54}}},"7":{"name":"(anonymous_7)","line":35,"loc":{"start":{"line":35,"column":32},"end":{"line":35,"column":48}}}},"statementMap":{"1":{"start":{"line":1,"column":0},"end":{"line":1,"column":27}},"2":{"start":{"line":2,"column":0},"end":{"line":2,"column":22}},"3":{"start":{"line":4,"column":0},"end":{"line":6,"column":1}},"4":{"start":{"line":5,"column":2},"end":{"line":5,"column":14}},"5":{"start":{"line":8,"column":0},"end":{"line":20,"column":1}},"6":{"start":{"line":9,"column":2},"end":{"line":19,"column":4}},"7":{"start":{"line":10,"column":4},"end":{"line":18,"column":5}},"8":{"start":{"line":11,"column":6},"end":{"line":11,"column":74}},"9":{"start":{"line":12,"column":11},"end":{"line":18,"column":5}},"10":{"start":{"line":13,"column":6},"end":{"line":13,"column":64}},"11":{"start":{"line":15,"column":6},"end":{"line":17,"column":9}},"12":{"start":{"line":16,"column":8},"end":{"line":16,"column":31}},"13":{"start":{"line":22,"column":0},"end":{"line":40,"column":1}},"14":{"start":{"line":23,"column":2},"end":{"line":27,"column":3}},"15":{"start":{"line":29,"column":2},"end":{"line":39,"column":4}},"16":{"start":{"line":30,"column":4},"end":{"line":38,"column":5}},"17":{"start":{"line":31,"column":6},"end":{"line":31,"column":74}},"18":{"start":{"line":32,"column":11},"end":{"line":38,"column":5}},"19":{"start":{"line":33,"column":6},"end":{"line":33,"column":64}},"20":{"start":{"line":35,"column":6},"end":{"line":37,"column":9}},"21":{"start":{"line":36,"column":8},"end":{"line":36,"column":31}},"22":{"start":{"line":42,"column":0},"end":{"line":42,"column":22}}},"branchMap":{"1":{"line":10,"type":"if","locations":[{"start":{"line":10,"column":4},"end":{"line":10,"column":4}},{"start":{"line":10,"column":4},"end":{"line":10,"column":4}}]},"2":{"line":11,"type":"binary-expr","locations":[{"start":{"line":11,"column":15},"end":{"line":11,"column":20}},{"start":{"line":11,"column":24},"end":{"line":11,"column":62}}]},"3":{"line":12,"type":"if","locations":[{"start":{"line":12,"column":11},"end":{"line":12,"column":11}},{"start":{"line":12,"column":11},"end":{"line":12,"column":11}}]},"4":{"line":13,"type":"binary-expr","locations":[{"start":{"line":13,"column":15},"end":{"line":13,"column":20}},{"start":{"line":13,"column":24},"end":{"line":13,"column":52}}]},"5":{"line":30,"type":"if","locations":[{"start":{"line":30,"column":4},"end":{"line":30,"column":4}},{"start":{"line":30,"column":4},"end":{"line":30,"column":4}}]},"6":{"line":31,"type":"binary-expr","locations":[{"start":{"line":31,"column":15},"end":{"line":31,"column":20}},{"start":{"line":31,"column":24},"end":{"line":31,"column":62}}]},"7":{"line":32,"type":"if","locations":[{"start":{"line":32,"column":11},"end":{"line":32,"column":11}},{"start":{"line":32,"column":11},"end":{"line":32,"column":11}}]},"8":{"line":33,"type":"binary-expr","locations":[{"start":{"line":33,"column":15},"end":{"line":33,"column":20}},{"start":{"line":33,"column":24},"end":{"line":33,"column":52}}]}}},"/Users/sakne/C5/projects/VideoStoreAPI/models/rental.js":{"path":"/Users/sakne/C5/projects/VideoStoreAPI/models/rental.js","s":{"1":1,"2":1,"3":1,"4":1,"5":1,"6":0,"7":1,"8":0,"9":0,"10":0,"11":0,"12":1,"13":0,"14":0,"15":0,"16":0,"17":0,"18":1,"19":0,"20":0,"21":0,"22":0,"23":0,"24":1,"25":0,"26":0,"27":0,"28":0,"29":0,"30":1,"31":0,"32":0,"33":0,"34":0,"35":0,"36":1},"b":{"1":[0,0],"2":[0,0],"3":[0,0],"4":[0,0],"5":[0,0]},"f":{"1":0,"2":0,"3":0,"4":0,"5":0,"6":0,"7":0,"8":0,"9":0,"10":0,"11":0},"fnMap":{"1":{"name":"(anonymous_1)","line":6,"loc":{"start":{"line":6,"column":13},"end":{"line":6,"column":26}}},"2":{"name":"(anonymous_2)","line":10,"loc":{"start":{"line":10,"column":14},"end":{"line":10,"column":40}}},"3":{"name":"(anonymous_3)","line":11,"loc":{"start":{"line":11,"column":149},"end":{"line":11,"column":174}}},"4":{"name":"(anonymous_4)","line":22,"loc":{"start":{"line":22,"column":23},"end":{"line":22,"column":58}}},"5":{"name":"(anonymous_5)","line":26,"loc":{"start":{"line":26,"column":165},"end":{"line":26,"column":192}}},"6":{"name":"(anonymous_6)","line":35,"loc":{"start":{"line":35,"column":20},"end":{"line":35,"column":56}}},"7":{"name":"(anonymous_7)","line":39,"loc":{"start":{"line":39,"column":140},"end":{"line":39,"column":164}}},"8":{"name":"(anonymous_8)","line":48,"loc":{"start":{"line":48,"column":23},"end":{"line":48,"column":62}}},"9":{"name":"(anonymous_9)","line":49,"loc":{"start":{"line":49,"column":169},"end":{"line":49,"column":199}}},"10":{"name":"(anonymous_10)","line":59,"loc":{"start":{"line":59,"column":25},"end":{"line":59,"column":70}}},"11":{"name":"(anonymous_11)","line":60,"loc":{"start":{"line":60,"column":97},"end":{"line":60,"column":127}}}},"statementMap":{"1":{"start":{"line":1,"column":0},"end":{"line":1,"column":27}},"2":{"start":{"line":2,"column":0},"end":{"line":2,"column":44}},"3":{"start":{"line":3,"column":0},"end":{"line":3,"column":38}},"4":{"start":{"line":4,"column":0},"end":{"line":4,"column":22}},"5":{"start":{"line":6,"column":0},"end":{"line":8,"column":1}},"6":{"start":{"line":7,"column":2},"end":{"line":7,"column":14}},"7":{"start":{"line":10,"column":0},"end":{"line":20,"column":1}},"8":{"start":{"line":11,"column":2},"end":{"line":19,"column":4}},"9":{"start":{"line":14,"column":4},"end":{"line":18,"column":5}},"10":{"start":{"line":15,"column":6},"end":{"line":15,"column":32}},"11":{"start":{"line":17,"column":6},"end":{"line":17,"column":29}},"12":{"start":{"line":22,"column":0},"end":{"line":33,"column":1}},"13":{"start":{"line":23,"column":2},"end":{"line":25,"column":3}},"14":{"start":{"line":26,"column":2},"end":{"line":32,"column":4}},"15":{"start":{"line":27,"column":4},"end":{"line":31,"column":5}},"16":{"start":{"line":28,"column":6},"end":{"line":28,"column":32}},"17":{"start":{"line":30,"column":6},"end":{"line":30,"column":31}},"18":{"start":{"line":35,"column":0},"end":{"line":46,"column":1}},"19":{"start":{"line":36,"column":2},"end":{"line":38,"column":3}},"20":{"start":{"line":39,"column":2},"end":{"line":45,"column":4}},"21":{"start":{"line":40,"column":4},"end":{"line":44,"column":5}},"22":{"start":{"line":41,"column":6},"end":{"line":41,"column":32}},"23":{"start":{"line":43,"column":6},"end":{"line":43,"column":28}},"24":{"start":{"line":48,"column":0},"end":{"line":57,"column":1}},"25":{"start":{"line":49,"column":2},"end":{"line":56,"column":4}},"26":{"start":{"line":50,"column":4},"end":{"line":55,"column":5}},"27":{"start":{"line":51,"column":6},"end":{"line":51,"column":32}},"28":{"start":{"line":53,"column":6},"end":{"line":53,"column":49}},"29":{"start":{"line":54,"column":6},"end":{"line":54,"column":34}},"30":{"start":{"line":59,"column":0},"end":{"line":68,"column":1}},"31":{"start":{"line":60,"column":2},"end":{"line":67,"column":4}},"32":{"start":{"line":61,"column":4},"end":{"line":66,"column":5}},"33":{"start":{"line":62,"column":6},"end":{"line":62,"column":32}},"34":{"start":{"line":64,"column":6},"end":{"line":64,"column":49}},"35":{"start":{"line":65,"column":6},"end":{"line":65,"column":34}},"36":{"start":{"line":70,"column":0},"end":{"line":70,"column":23}}},"branchMap":{"1":{"line":14,"type":"if","locations":[{"start":{"line":14,"column":4},"end":{"line":14,"column":4}},{"start":{"line":14,"column":4},"end":{"line":14,"column":4}}]},"2":{"line":27,"type":"if","locations":[{"start":{"line":27,"column":4},"end":{"line":27,"column":4}},{"start":{"line":27,"column":4},"end":{"line":27,"column":4}}]},"3":{"line":40,"type":"if","locations":[{"start":{"line":40,"column":4},"end":{"line":40,"column":4}},{"start":{"line":40,"column":4},"end":{"line":40,"column":4}}]},"4":{"line":50,"type":"if","locations":[{"start":{"line":50,"column":4},"end":{"line":50,"column":4}},{"start":{"line":50,"column":4},"end":{"line":50,"column":4}}]},"5":{"line":61,"type":"if","locations":[{"start":{"line":61,"column":4},"end":{"line":61,"column":4}},{"start":{"line":61,"column":4},"end":{"line":61,"column":4}}]}}},"/Users/sakne/C5/projects/VideoStoreAPI/models/customer.js":{"path":"/Users/sakne/C5/projects/VideoStoreAPI/models/customer.js","s":{"1":1,"2":1,"3":1,"4":400,"5":1,"6":2,"7":2,"8":0,"9":2,"10":0,"11":2,"12":400,"13":1,"14":1,"15":1,"16":1,"17":1,"18":0,"19":0,"20":0,"21":0,"22":1,"23":0,"24":0,"25":0,"26":1},"b":{"1":[0,2],"2":[0,0],"3":[0,2],"4":[0,0],"5":[1,0],"6":[1,0],"7":[0,0],"8":[0,0]},"f":{"1":400,"2":2,"3":2,"4":400,"5":1,"6":1,"7":0,"8":0,"9":0},"fnMap":{"1":{"name":"(anonymous_1)","line":4,"loc":{"start":{"line":4,"column":15},"end":{"line":4,"column":28}}},"2":{"name":"(anonymous_2)","line":8,"loc":{"start":{"line":8,"column":15},"end":{"line":8,"column":34}}},"3":{"name":"(anonymous_3)","line":9,"loc":{"start":{"line":9,"column":20},"end":{"line":9,"column":47}}},"4":{"name":"(anonymous_4)","line":15,"loc":{"start":{"line":15,"column":35},"end":{"line":15,"column":54}}},"5":{"name":"(anonymous_5)","line":22,"loc":{"start":{"line":22,"column":16},"end":{"line":22,"column":63}}},"6":{"name":"(anonymous_6)","line":30,"loc":{"start":{"line":30,"column":33},"end":{"line":30,"column":60}}},"7":{"name":"(anonymous_7)","line":36,"loc":{"start":{"line":36,"column":35},"end":{"line":36,"column":54}}},"8":{"name":"(anonymous_8)","line":44,"loc":{"start":{"line":44,"column":19},"end":{"line":44,"column":64}}},"9":{"name":"(anonymous_9)","line":50,"loc":{"start":{"line":50,"column":33},"end":{"line":50,"column":59}}}},"statementMap":{"1":{"start":{"line":1,"column":0},"end":{"line":1,"column":27}},"2":{"start":{"line":2,"column":0},"end":{"line":2,"column":22}},"3":{"start":{"line":4,"column":0},"end":{"line":6,"column":1}},"4":{"start":{"line":5,"column":2},"end":{"line":5,"column":14}},"5":{"start":{"line":8,"column":0},"end":{"line":20,"column":1}},"6":{"start":{"line":9,"column":2},"end":{"line":19,"column":4}},"7":{"start":{"line":10,"column":4},"end":{"line":18,"column":5}},"8":{"start":{"line":11,"column":6},"end":{"line":11,"column":77}},"9":{"start":{"line":12,"column":11},"end":{"line":18,"column":5}},"10":{"start":{"line":13,"column":6},"end":{"line":13,"column":67}},"11":{"start":{"line":15,"column":6},"end":{"line":17,"column":9}},"12":{"start":{"line":16,"column":8},"end":{"line":16,"column":37}},"13":{"start":{"line":22,"column":0},"end":{"line":42,"column":1}},"14":{"start":{"line":23,"column":2},"end":{"line":28,"column":3}},"15":{"start":{"line":30,"column":2},"end":{"line":41,"column":4}},"16":{"start":{"line":31,"column":4},"end":{"line":40,"column":5}},"17":{"start":{"line":32,"column":6},"end":{"line":32,"column":77}},"18":{"start":{"line":33,"column":11},"end":{"line":40,"column":5}},"19":{"start":{"line":34,"column":6},"end":{"line":34,"column":67}},"20":{"start":{"line":36,"column":6},"end":{"line":39,"column":9}},"21":{"start":{"line":38,"column":8},"end":{"line":38,"column":37}},"22":{"start":{"line":44,"column":0},"end":{"line":62,"column":1}},"23":{"start":{"line":45,"column":2},"end":{"line":48,"column":3}},"24":{"start":{"line":50,"column":2},"end":{"line":61,"column":4}},"25":{"start":{"line":58,"column":8},"end":{"line":58,"column":37}},"26":{"start":{"line":65,"column":0},"end":{"line":65,"column":25}}},"branchMap":{"1":{"line":10,"type":"if","locations":[{"start":{"line":10,"column":4},"end":{"line":10,"column":4}},{"start":{"line":10,"column":4},"end":{"line":10,"column":4}}]},"2":{"line":11,"type":"binary-expr","locations":[{"start":{"line":11,"column":15},"end":{"line":11,"column":20}},{"start":{"line":11,"column":24},"end":{"line":11,"column":65}}]},"3":{"line":12,"type":"if","locations":[{"start":{"line":12,"column":11},"end":{"line":12,"column":11}},{"start":{"line":12,"column":11},"end":{"line":12,"column":11}}]},"4":{"line":13,"type":"binary-expr","locations":[{"start":{"line":13,"column":15},"end":{"line":13,"column":20}},{"start":{"line":13,"column":24},"end":{"line":13,"column":55}}]},"5":{"line":31,"type":"if","locations":[{"start":{"line":31,"column":4},"end":{"line":31,"column":4}},{"start":{"line":31,"column":4},"end":{"line":31,"column":4}}]},"6":{"line":32,"type":"binary-expr","locations":[{"start":{"line":32,"column":15},"end":{"line":32,"column":20}},{"start":{"line":32,"column":24},"end":{"line":32,"column":65}}]},"7":{"line":33,"type":"if","locations":[{"start":{"line":33,"column":11},"end":{"line":33,"column":11}},{"start":{"line":33,"column":11},"end":{"line":33,"column":11}}]},"8":{"line":34,"type":"binary-expr","locations":[{"start":{"line":34,"column":15},"end":{"line":34,"column":20}},{"start":{"line":34,"column":24},"end":{"line":34,"column":55}}]}}},"/Users/sakne/C5/projects/VideoStoreAPI/controllers/customers_controller.js":{"path":"/Users/sakne/C5/projects/VideoStoreAPI/controllers/customers_controller.js","s":{"1":1,"2":1,"3":1,"4":0,"5":0,"6":0,"7":0,"8":0,"9":0,"10":0,"11":0,"12":0,"13":0,"14":0,"15":0,"16":0,"17":0,"18":0,"19":0,"20":0,"21":0,"22":0,"23":0,"24":0,"25":0,"26":0,"27":0,"28":1},"b":{"1":[0,0],"2":[0,0],"3":[0,0],"4":[0,0]},"f":{"1":0,"2":0,"3":0,"4":0,"5":0,"6":0,"7":0,"8":0},"fnMap":{"1":{"name":"(anonymous_1)","line":6,"loc":{"start":{"line":6,"column":9},"end":{"line":6,"column":34}}},"2":{"name":"(anonymous_2)","line":7,"loc":{"start":{"line":7,"column":17},"end":{"line":7,"column":44}}},"3":{"name":"(anonymous_3)","line":18,"loc":{"start":{"line":18,"column":8},"end":{"line":18,"column":33}}},"4":{"name":"(anonymous_4)","line":19,"loc":{"start":{"line":19,"column":88},"end":{"line":19,"column":115}}},"5":{"name":"(anonymous_5)","line":30,"loc":{"start":{"line":30,"column":11},"end":{"line":30,"column":36}}},"6":{"name":"(anonymous_6)","line":31,"loc":{"start":{"line":31,"column":61},"end":{"line":31,"column":86}}},"7":{"name":"(anonymous_7)","line":42,"loc":{"start":{"line":42,"column":11},"end":{"line":42,"column":36}}},"8":{"name":"(anonymous_8)","line":43,"loc":{"start":{"line":43,"column":85},"end":{"line":43,"column":110}}}},"statementMap":{"1":{"start":{"line":1,"column":0},"end":{"line":1,"column":44}},"2":{"start":{"line":2,"column":0},"end":{"line":2,"column":40}},"3":{"start":{"line":4,"column":0},"end":{"line":53,"column":1}},"4":{"start":{"line":7,"column":4},"end":{"line":15,"column":6}},"5":{"start":{"line":8,"column":6},"end":{"line":14,"column":7}},"6":{"start":{"line":9,"column":8},"end":{"line":9,"column":76}},"7":{"start":{"line":10,"column":8},"end":{"line":10,"column":24}},"8":{"start":{"line":11,"column":8},"end":{"line":11,"column":17}},"9":{"start":{"line":13,"column":8},"end":{"line":13,"column":27}},"10":{"start":{"line":19,"column":4},"end":{"line":27,"column":6}},"11":{"start":{"line":20,"column":6},"end":{"line":26,"column":7}},"12":{"start":{"line":21,"column":8},"end":{"line":21,"column":76}},"13":{"start":{"line":22,"column":8},"end":{"line":22,"column":24}},"14":{"start":{"line":23,"column":8},"end":{"line":23,"column":17}},"15":{"start":{"line":25,"column":8},"end":{"line":25,"column":27}},"16":{"start":{"line":31,"column":4},"end":{"line":39,"column":6}},"17":{"start":{"line":32,"column":6},"end":{"line":38,"column":7}},"18":{"start":{"line":33,"column":8},"end":{"line":33,"column":71}},"19":{"start":{"line":34,"column":8},"end":{"line":34,"column":24}},"20":{"start":{"line":35,"column":8},"end":{"line":35,"column":17}},"21":{"start":{"line":37,"column":8},"end":{"line":37,"column":25}},"22":{"start":{"line":43,"column":4},"end":{"line":51,"column":6}},"23":{"start":{"line":44,"column":6},"end":{"line":50,"column":7}},"24":{"start":{"line":45,"column":8},"end":{"line":45,"column":74}},"25":{"start":{"line":46,"column":8},"end":{"line":46,"column":24}},"26":{"start":{"line":47,"column":8},"end":{"line":47,"column":17}},"27":{"start":{"line":49,"column":8},"end":{"line":49,"column":25}},"28":{"start":{"line":55,"column":0},"end":{"line":55,"column":36}}},"branchMap":{"1":{"line":8,"type":"if","locations":[{"start":{"line":8,"column":6},"end":{"line":8,"column":6}},{"start":{"line":8,"column":6},"end":{"line":8,"column":6}}]},"2":{"line":20,"type":"if","locations":[{"start":{"line":20,"column":6},"end":{"line":20,"column":6}},{"start":{"line":20,"column":6},"end":{"line":20,"column":6}}]},"3":{"line":32,"type":"if","locations":[{"start":{"line":32,"column":6},"end":{"line":32,"column":6}},{"start":{"line":32,"column":6},"end":{"line":32,"column":6}}]},"4":{"line":44,"type":"if","locations":[{"start":{"line":44,"column":6},"end":{"line":44,"column":6}},{"start":{"line":44,"column":6},"end":{"line":44,"column":6}}]}}},"/Users/sakne/C5/projects/VideoStoreAPI/controllers/rentals_controller.js":{"path":"/Users/sakne/C5/projects/VideoStoreAPI/controllers/rentals_controller.js","s":{"1":1,"2":1,"3":1,"4":1,"5":0,"6":0,"7":0,"8":0,"9":0,"10":0,"11":1},"b":{"1":[0,0]},"f":{"1":0,"2":0},"fnMap":{"1":{"name":"(anonymous_1)","line":6,"loc":{"start":{"line":6,"column":8},"end":{"line":6,"column":33}}},"2":{"name":"(anonymous_2)","line":7,"loc":{"start":{"line":7,"column":34},"end":{"line":7,"column":58}}}},"statementMap":{"1":{"start":{"line":1,"column":0},"end":{"line":1,"column":40}},"2":{"start":{"line":2,"column":0},"end":{"line":2,"column":38}},"3":{"start":{"line":3,"column":0},"end":{"line":3,"column":44}},"4":{"start":{"line":5,"column":0},"end":{"line":40,"column":1}},"5":{"start":{"line":7,"column":4},"end":{"line":16,"column":6}},"6":{"start":{"line":8,"column":6},"end":{"line":15,"column":7}},"7":{"start":{"line":9,"column":8},"end":{"line":9,"column":73}},"8":{"start":{"line":10,"column":8},"end":{"line":10,"column":24}},"9":{"start":{"line":11,"column":8},"end":{"line":11,"column":17}},"10":{"start":{"line":14,"column":8},"end":{"line":14,"column":24}},"11":{"start":{"line":42,"column":0},"end":{"line":42,"column":34}}},"branchMap":{"1":{"line":8,"type":"if","locations":[{"start":{"line":8,"column":6},"end":{"line":8,"column":6}},{"start":{"line":8,"column":6},"end":{"line":8,"column":6}}]}}},"/Users/sakne/C5/projects/VideoStoreAPI/routes/zomg.js":{"path":"/Users/sakne/C5/projects/VideoStoreAPI/routes/zomg.js","s":{"1":1,"2":1,"3":1,"4":1,"5":0,"6":1},"b":{},"f":{"1":0},"fnMap":{"1":{"name":"(anonymous_1)","line":30,"loc":{"start":{"line":30,"column":16},"end":{"line":30,"column":41}}}},"statementMap":{"1":{"start":{"line":25,"column":0},"end":{"line":25,"column":33}},"2":{"start":{"line":26,"column":0},"end":{"line":26,"column":30}},"3":{"start":{"line":27,"column":0},"end":{"line":27,"column":15}},"4":{"start":{"line":30,"column":0},"end":{"line":32,"column":3}},"5":{"start":{"line":31,"column":2},"end":{"line":31,"column":44}},"6":{"start":{"line":34,"column":0},"end":{"line":34,"column":24}}},"branchMap":{}}}
\ No newline at end of file
diff --git a/coverage/lcov-report/VideoStoreAPI/app.js.html b/coverage/lcov-report/VideoStoreAPI/app.js.html
new file mode 100644
index 000000000..801410501
--- /dev/null
+++ b/coverage/lcov-report/VideoStoreAPI/app.js.html
@@ -0,0 +1,257 @@
+
+
+
+ Code coverage report for VideoStoreAPI/app.js
+
+
+
+
+
+
+
+
+
+
+
+
+ 75.76%
+ Statements
+ 25/33
+
+
+ 16.67%
+ Branches
+ 1/6
+
+
+ 0%
+ Functions
+ 0/3
+
+
+ 75.76%
+ Lines
+ 25/33
+
+
+
+
+
+| 1
+2
+3
+4
+5
+6
+7
+8
+9
+10
+11
+12
+13
+14
+15
+16
+17
+18
+19
+20
+21
+22
+23
+24
+25
+26
+27
+28
+29
+30
+31
+32
+33
+34
+35
+36
+37
+38
+39
+40
+41
+42
+43
+44
+45
+46
+47
+48
+49
+50
+51
+52
+53
+54
+55
+56
+57
+58
+59
+60
+61
+62
+63
+64
+65 | 1×
+1×
+1×
+1×
+1×
+1×
+
+1×
+1×
+
+1×
+
+1×
+1×
+
+
+1×
+1×
+
+1×
+
+1×
+
+
+
+1×
+1×
+1×
+1×
+1×
+
+1×
+1×
+
+
+1×
+
+
+
+
+
+
+
+
+
+1×
+
+
+
+
+
+
+
+
+
+
+
+1×
+
+
+
+
+
+
+ | var express = require('express')
+var path = require('path')
+var favicon = require('serve-favicon')
+var logger = require('morgan')
+var cookieParser = require('cookie-parser')
+var bodyParser = require('body-parser')
+
+var massive = require('massive')
+var connectionString = "postgres://localhost/video-store-api"
+
+var app = module.exports = express()
+
+var db = massive.connectSync({connectionString : connectionString})
+app.set('db', db)
+
+// view engine setup
+app.set('views', path.join(__dirname, 'views'))
+app.set('view engine', 'jade')
+
+var routes = require('./routes/index')
+
+var zomgRoutes = require('./routes/zomg')
+
+// uncomment after placing your favicon in /public
+//app.use(favicon(path.join(__dirname, 'public', 'favicon.ico')))
+app.use(logger('dev'))
+app.use(bodyParser.json())
+app.use(bodyParser.urlencoded({ extended: false }))
+app.use(cookieParser())
+app.use(express.static(path.join(__dirname, 'public')))
+
+app.use('/', routes)
+app.use('/zomg', zomgRoutes)
+
+// catch 404 and forward to error handler
+app.use(function(req, res, next) {
+ var err = new Error('Not Found')
+ err.status = 404
+ next(err)
+})
+
+// error handlers
+
+// development error handler
+// will print stacktrace
+Iif (app.get('env') === 'development') {
+ app.use(function(err, req, res, next) {
+ res.status(err.status || 500)
+ res.render('error', {
+ message: err.message,
+ error: err
+ })
+ })
+}
+
+// production error handler
+// no stacktraces leaked to user
+app.use(function(err, req, res, next) {
+ res.status(err.status || 500)
+ res.render('error', {
+ message: err.message,
+ error: {}
+ })
+})
+ |
+
+
+
+
+
+
+
+
+
+
diff --git a/coverage/lcov-report/VideoStoreAPI/controllers/customers_controller.js.html b/coverage/lcov-report/VideoStoreAPI/controllers/customers_controller.js.html
new file mode 100644
index 000000000..c602f35b4
--- /dev/null
+++ b/coverage/lcov-report/VideoStoreAPI/controllers/customers_controller.js.html
@@ -0,0 +1,230 @@
+
+
+
+ Code coverage report for VideoStoreAPI/controllers/customers_controller.js
+
+
+
+
+
+
+
+
+
+
+
+
+ 14.29%
+ Statements
+ 4/28
+
+
+ 0%
+ Branches
+ 0/8
+
+
+ 0%
+ Functions
+ 0/8
+
+
+ 14.29%
+ Lines
+ 4/28
+
+
+
+
+
+| 1
+2
+3
+4
+5
+6
+7
+8
+9
+10
+11
+12
+13
+14
+15
+16
+17
+18
+19
+20
+21
+22
+23
+24
+25
+26
+27
+28
+29
+30
+31
+32
+33
+34
+35
+36
+37
+38
+39
+40
+41
+42
+43
+44
+45
+46
+47
+48
+49
+50
+51
+52
+53
+54
+55
+56 | 1×
+1×
+
+1×
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+1×
+ | var Customer = require("../models/customer")
+var Rental = require("../models/rental")
+
+var CustomersController = {
+
+ index: function(req, res, next) {
+ Customer.all(function(error, customers) {
+ if(error) {
+ var err = new Error("Error retrieving customers:\n" + error.message)
+ err.status = 500
+ next(err)
+ } else {
+ res.json(customers)
+ }
+ })
+ },
+
+ sort: function(req, res, next) {
+ Customer.sort(req.params.column_name, req.params.columns, req.query.n, req.query.p, function(error, customers) {
+ if(error) {
+ var err = new Error("Error retrieving customers:\n" + error.message)
+ err.status = 500
+ next(err)
+ } else {
+ res.json(customers)
+ }
+ })
+ },
+
+ current: function(req, res, next) {
+ Rental.current_id(req.params.id, req.params.column_name, function(error, rentals) {
+ if(error) {
+ var err = new Error("Error retrieving rentals" + error.message)
+ err.status = 500
+ next(err)
+ } else {
+ res.json(rentals)
+ }
+ })
+ },
+
+ history: function(req, res, next) {
+ Rental.history_cust_id(req.params.id, req.params.column_name, req.params.column, function(error, rentals) {
+ if(error) {
+ var err = new Error("Error retrieving rentals:\n" + error.message)
+ err.status = 500
+ next(err)
+ } else {
+ res.json(rentals)
+ }
+ })
+ }
+}
+
+module.exports = CustomersController
+ |
+
+
+
+
+
+
+
+
+
+
diff --git a/coverage/lcov-report/VideoStoreAPI/controllers/index.html b/coverage/lcov-report/VideoStoreAPI/controllers/index.html
new file mode 100644
index 000000000..42759e11a
--- /dev/null
+++ b/coverage/lcov-report/VideoStoreAPI/controllers/index.html
@@ -0,0 +1,119 @@
+
+
+
+ Code coverage report for VideoStoreAPI/controllers/
+
+
+
+
+
+
+
+
+
+
+ all files VideoStoreAPI/controllers/
+
+
+
+ 19.4%
+ Statements
+ 13/67
+
+
+ 0%
+ Branches
+ 0/18
+
+
+ 0%
+ Functions
+ 0/18
+
+
+ 19.4%
+ Lines
+ 13/67
+
+
+
+
+
+
+
+
+ | File |
+ |
+ Statements |
+ |
+ Branches |
+ |
+ Functions |
+ |
+ Lines |
+ |
+
+
+
+ | customers_controller.js |
+ |
+ 14.29% |
+ 4/28 |
+ 0% |
+ 0/8 |
+ 0% |
+ 0/8 |
+ 14.29% |
+ 4/28 |
+
+
+
+ | movies_controller.js |
+ |
+ 14.29% |
+ 4/28 |
+ 0% |
+ 0/8 |
+ 0% |
+ 0/8 |
+ 14.29% |
+ 4/28 |
+
+
+
+ | rentals_controller.js |
+ |
+ 45.45% |
+ 5/11 |
+ 0% |
+ 0/2 |
+ 0% |
+ 0/2 |
+ 45.45% |
+ 5/11 |
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/coverage/lcov-report/VideoStoreAPI/controllers/movies_controller.js.html b/coverage/lcov-report/VideoStoreAPI/controllers/movies_controller.js.html
new file mode 100644
index 000000000..e4a7db1ca
--- /dev/null
+++ b/coverage/lcov-report/VideoStoreAPI/controllers/movies_controller.js.html
@@ -0,0 +1,230 @@
+
+
+
+ Code coverage report for VideoStoreAPI/controllers/movies_controller.js
+
+
+
+
+
+
+
+
+
+
+
+
+ 14.29%
+ Statements
+ 4/28
+
+
+ 0%
+ Branches
+ 0/8
+
+
+ 0%
+ Functions
+ 0/8
+
+
+ 14.29%
+ Lines
+ 4/28
+
+
+
+
+
+| 1
+2
+3
+4
+5
+6
+7
+8
+9
+10
+11
+12
+13
+14
+15
+16
+17
+18
+19
+20
+21
+22
+23
+24
+25
+26
+27
+28
+29
+30
+31
+32
+33
+34
+35
+36
+37
+38
+39
+40
+41
+42
+43
+44
+45
+46
+47
+48
+49
+50
+51
+52
+53
+54
+55
+56 | 1×
+1×
+
+1×
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+1×
+ | var Movie = require("../models/movie")
+var Rental = require("../models/rental")
+
+var MoviesController = {
+
+ index: function(req, res, next) {
+ Movie.all(function(error, movies) {
+ if(error) {
+ var err = new Error("Error retrieving movies:\n" + error.message)
+ err.status = 500
+ next(err)
+ } else {
+ res.json(movies)
+ }
+ })
+ },
+
+ sort: function(req, res, next) {
+ Movie.sort(req.params.column_name, req.query.n, req.query.p, function(error, movies) {
+ if(error) {
+ var err = new Error("Error retrieving movies:\n" + error.message)
+ err.status = 500
+ next(err)
+ } else {
+ res.json(movies)
+ }
+ })
+ },
+
+ current: function(req, res, next) {
+ Rental.current_title(req.params.title, req.params.columns, function(error, rentals) {
+ if(error) {
+ var err = new Error("Error retrieving rentals:\n" + error.message)
+ err.status = 500
+ next(err)
+ } else {
+ res.json(rentals)
+ }
+ })
+ },
+
+ history: function(req, res, next) {
+ Rental.history_title(req.params.title, req.params.column_name, function(error, rentals) {
+ if(error) {
+ var err = new Error("Error retrieving rentals:\n" + error.message)
+ err.status = 500
+ next(err)
+ } else {
+ res.json(rentals)
+ }
+ })
+ }
+}
+
+module.exports = MoviesController
+ |
+
+
+
+
+
+
+
+
+
+
diff --git a/coverage/lcov-report/VideoStoreAPI/controllers/rentals_controller.js.html b/coverage/lcov-report/VideoStoreAPI/controllers/rentals_controller.js.html
new file mode 100644
index 000000000..2b7866136
--- /dev/null
+++ b/coverage/lcov-report/VideoStoreAPI/controllers/rentals_controller.js.html
@@ -0,0 +1,191 @@
+
+
+
+ Code coverage report for VideoStoreAPI/controllers/rentals_controller.js
+
+
+
+
+
+
+
+
+
+
+
+
+ 45.45%
+ Statements
+ 5/11
+
+
+ 0%
+ Branches
+ 0/2
+
+
+ 0%
+ Functions
+ 0/2
+
+
+ 45.45%
+ Lines
+ 5/11
+
+
+
+
+
+| 1
+2
+3
+4
+5
+6
+7
+8
+9
+10
+11
+12
+13
+14
+15
+16
+17
+18
+19
+20
+21
+22
+23
+24
+25
+26
+27
+28
+29
+30
+31
+32
+33
+34
+35
+36
+37
+38
+39
+40
+41
+42
+43 | 1×
+1×
+1×
+
+1×
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+1×
+ | var Rental = require("../models/rental")
+var Movie = require("../models/movie")
+var Customer = require("../models/customer")
+
+var RentalsController = {
+ view: function(req, res, next) {
+ Rental.view(req.params.title, function(error, movies) {
+ if(error) {
+ var err = new Error("Error retrieving movies:\n" + error.message)
+ err.status = 500
+ next(err)
+ } else {
+ // console.log(res.json(movies))
+ res.json(movies)
+ }
+ })
+ }
+
+// getRentals: function(req, res) {
+// Movie.findMovie(req.params.title, function(error, movie) {
+// if(error) {
+// var err = new Error("No such movie");
+// err.status = 404;
+// } else {
+// Rental.getCurrentlyCheckedOut(movie, function(error, checked_out) {
+// var return_data = {
+// title:movie.title,
+// overview:movie.overview,
+// release_date:movie.release_date,
+// total_inventory:movie.inventory,
+// available_copies:(parseInt(movie.inventory))-(parseInt(checked_out))
+// }
+// res.json(return_data)
+// })
+// }
+//
+// })
+// },
+
+}
+
+module.exports = RentalsController
+ |
+
+
+
+
+
+
+
+
+
+
diff --git a/coverage/lcov-report/VideoStoreAPI/index.html b/coverage/lcov-report/VideoStoreAPI/index.html
new file mode 100644
index 000000000..c694025fe
--- /dev/null
+++ b/coverage/lcov-report/VideoStoreAPI/index.html
@@ -0,0 +1,93 @@
+
+
+
+ Code coverage report for VideoStoreAPI/
+
+
+
+
+
+
+
+
+
+
+ all files VideoStoreAPI/
+
+
+
+ 75.76%
+ Statements
+ 25/33
+
+
+ 16.67%
+ Branches
+ 1/6
+
+
+ 0%
+ Functions
+ 0/3
+
+
+ 75.76%
+ Lines
+ 25/33
+
+
+
+
+
+
+
+
+ | File |
+ |
+ Statements |
+ |
+ Branches |
+ |
+ Functions |
+ |
+ Lines |
+ |
+
+
+
+ | app.js |
+ |
+ 75.76% |
+ 25/33 |
+ 16.67% |
+ 1/6 |
+ 0% |
+ 0/3 |
+ 75.76% |
+ 25/33 |
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/coverage/lcov-report/VideoStoreAPI/models/customer.js.html b/coverage/lcov-report/VideoStoreAPI/models/customer.js.html
new file mode 100644
index 000000000..6eb0ee07d
--- /dev/null
+++ b/coverage/lcov-report/VideoStoreAPI/models/customer.js.html
@@ -0,0 +1,260 @@
+
+
+
+ Code coverage report for VideoStoreAPI/models/customer.js
+
+
+
+
+
+
+
+
+
+
+
+
+ 65.38%
+ Statements
+ 17/26
+
+
+ 25%
+ Branches
+ 4/16
+
+
+ 66.67%
+ Functions
+ 6/9
+
+
+ 65.38%
+ Lines
+ 17/26
+
+
+
+
+
+| 1
+2
+3
+4
+5
+6
+7
+8
+9
+10
+11
+12
+13
+14
+15
+16
+17
+18
+19
+20
+21
+22
+23
+24
+25
+26
+27
+28
+29
+30
+31
+32
+33
+34
+35
+36
+37
+38
+39
+40
+41
+42
+43
+44
+45
+46
+47
+48
+49
+50
+51
+52
+53
+54
+55
+56
+57
+58
+59
+60
+61
+62
+63
+64
+65
+66 | 1×
+1×
+
+1×
+400×
+
+
+1×
+2×
+2×
+
+2×
+
+
+2×
+400×
+
+
+
+
+
+1×
+1×
+
+
+
+
+
+
+1×
+1×
+1×
+
+
+
+
+
+
+
+
+
+
+
+1×
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+1×
+ | var app = require("../app")
+var db = app.get('db')
+
+var Customer = function(id) {
+ this.id = id
+}
+
+Customer.all = function(callback) {
+ db.customers.find(function(error, customers) {
+ Iif(error) {
+ callback(error || new Error("Could not retrieve customers"), undefined)
+ } else Iif(!customers) {
+ callback(error || new Error("No customers found"), undefined)
+ } else {
+ callback(null, customers.map(function(customer) {
+ return new Customer(customer)
+ }))
+ }
+ })
+}
+
+Customer.sort = function(column_name, columns, n, p, callback) {
+ var options = {
+ limit : n,
+ offset : p,
+ columns : ["name", "registered_at", "postal_code"],
+ order : column_name
+ }
+
+ db.customers.find({}, options, function(error, customers) {
+ Eif(error) {
+ callback(error || new Error("Could not retrieve customers"), undefined)
+ } else if(!customers) {
+ callback(error || new Error("No customers found"), undefined)
+ } else {
+ callback(null, customers.map(function(customer) {
+ // console.log(customer)
+ return new Customer(customer)
+ }))
+ }
+ })
+}
+
+Customer.find_id = function(customer_ids, column_name, columns) {
+ var options = {
+ order : column_name,
+ columns : ['name', 'phone', 'account_credit']
+ }
+
+ db.customers.find({}, options, function(error, customer) {
+ // if(error) {
+ // callback(error || new Error("Could not retrieve customers"), undefined)
+ // } else if(!customers) {
+ // callback(error || new Error("No customers found"), undefined)
+ // } else {
+ // callback(null, customers.map(function(customer) {
+ // console.log(customer)
+ return new Customer(customer)
+ // }))
+ // }
+ })
+}
+
+
+module.exports = Customer
+ |
+
+
+
+
+
+
+
+
+
+
diff --git a/coverage/lcov-report/VideoStoreAPI/models/index.html b/coverage/lcov-report/VideoStoreAPI/models/index.html
new file mode 100644
index 000000000..1b10c130d
--- /dev/null
+++ b/coverage/lcov-report/VideoStoreAPI/models/index.html
@@ -0,0 +1,119 @@
+
+
+
+ Code coverage report for VideoStoreAPI/models/
+
+
+
+
+
+
+
+
+
+
+ all files VideoStoreAPI/models/
+
+
+
+ 40.48%
+ Statements
+ 34/84
+
+
+ 9.52%
+ Branches
+ 4/42
+
+
+ 22.22%
+ Functions
+ 6/27
+
+
+ 40.48%
+ Lines
+ 34/84
+
+
+
+
+
+
+
+
+ | File |
+ |
+ Statements |
+ |
+ Branches |
+ |
+ Functions |
+ |
+ Lines |
+ |
+
+
+
+ | customer.js |
+ |
+ 65.38% |
+ 17/26 |
+ 25% |
+ 4/16 |
+ 66.67% |
+ 6/9 |
+ 65.38% |
+ 17/26 |
+
+
+
+ | movie.js |
+ |
+ 27.27% |
+ 6/22 |
+ 0% |
+ 0/16 |
+ 0% |
+ 0/7 |
+ 27.27% |
+ 6/22 |
+
+
+
+ | rental.js |
+ |
+ 30.56% |
+ 11/36 |
+ 0% |
+ 0/10 |
+ 0% |
+ 0/11 |
+ 30.56% |
+ 11/36 |
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/coverage/lcov-report/VideoStoreAPI/models/movie.js.html b/coverage/lcov-report/VideoStoreAPI/models/movie.js.html
new file mode 100644
index 000000000..66a910e92
--- /dev/null
+++ b/coverage/lcov-report/VideoStoreAPI/models/movie.js.html
@@ -0,0 +1,191 @@
+
+
+
+ Code coverage report for VideoStoreAPI/models/movie.js
+
+
+
+
+
+
+
+
+
+
+
+
+ 27.27%
+ Statements
+ 6/22
+
+
+ 0%
+ Branches
+ 0/16
+
+
+ 0%
+ Functions
+ 0/7
+
+
+ 27.27%
+ Lines
+ 6/22
+
+
+
+
+
+| 1
+2
+3
+4
+5
+6
+7
+8
+9
+10
+11
+12
+13
+14
+15
+16
+17
+18
+19
+20
+21
+22
+23
+24
+25
+26
+27
+28
+29
+30
+31
+32
+33
+34
+35
+36
+37
+38
+39
+40
+41
+42
+43 | 1×
+1×
+
+1×
+
+
+
+1×
+
+
+
+
+
+
+
+
+
+
+
+
+
+1×
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+1×
+ | var app = require("../app")
+var db = app.get('db')
+
+var Movie = function(id) {
+ this.id = id
+}
+
+Movie.all = function(callback) {
+ db.movies.find(function(error, movies) {
+ if(error) {
+ callback(error || new Error("Could not retrieve movies"), undefined)
+ } else if(!movies) {
+ callback(error || new Error("No movies found"), undefined)
+ } else {
+ callback(null, movies.map(function(movie) {
+ return new Movie(movie)
+ }))
+ }
+ })
+}
+
+Movie.sort = function(column_name, n, p, callback) {
+ var options = {
+ order : column_name,
+ limit : n,
+ offset : p
+ }
+
+ db.movies.find({}, options, function(error, movies) {
+ if(error) {
+ callback(error || new Error("Could not retrieve movies"), undefined)
+ } else if(!movies) {
+ callback(error || new Error("No movies found"), undefined)
+ } else {
+ callback(null, movies.map(function(movie) {
+ return new Movie(movie)
+ }))
+ }
+ })
+}
+
+module.exports = Movie
+ |
+
+
+
+
+
+
+
+
+
+
diff --git a/coverage/lcov-report/VideoStoreAPI/models/rental.js.html b/coverage/lcov-report/VideoStoreAPI/models/rental.js.html
new file mode 100644
index 000000000..c21cc15b6
--- /dev/null
+++ b/coverage/lcov-report/VideoStoreAPI/models/rental.js.html
@@ -0,0 +1,275 @@
+
+
+
+ Code coverage report for VideoStoreAPI/models/rental.js
+
+
+
+
+
+
+
+
+
+
+
+
+ 30.56%
+ Statements
+ 11/36
+
+
+ 0%
+ Branches
+ 0/10
+
+
+ 0%
+ Functions
+ 0/11
+
+
+ 30.56%
+ Lines
+ 11/36
+
+
+
+
+
+| 1
+2
+3
+4
+5
+6
+7
+8
+9
+10
+11
+12
+13
+14
+15
+16
+17
+18
+19
+20
+21
+22
+23
+24
+25
+26
+27
+28
+29
+30
+31
+32
+33
+34
+35
+36
+37
+38
+39
+40
+41
+42
+43
+44
+45
+46
+47
+48
+49
+50
+51
+52
+53
+54
+55
+56
+57
+58
+59
+60
+61
+62
+63
+64
+65
+66
+67
+68
+69
+70
+71 | 1×
+1×
+1×
+1×
+
+1×
+
+
+
+1×
+
+
+
+
+
+
+
+
+
+
+
+1×
+
+
+
+
+
+
+
+
+
+
+
+
+1×
+
+
+
+
+
+
+
+
+
+
+
+
+1×
+
+
+
+
+
+
+
+
+
+
+1×
+
+
+
+
+
+
+
+
+
+
+1×
+ | var app = require("../app")
+var Customer = require("../models/customer")
+var Movie = require("../models/movie")
+var db = app.get('db')
+// Constructor function
+var Rental = function(id) {
+ this.id = id
+}
+
+Rental.view = function(title, callback) {
+ db.run("SELECT overview, release_date FROM movies WHERE title IN (SELECT title FROM rentals where title = $1 AND returned_date IS null)", [title], function(error, rentals) {
+ // console.log("rentals: " + JSON.stringify(rentals))
+ // console.log("error: " + error)
+ if(error) {
+ callback(error, undefined)
+ } else {
+ callback(null, rentals)
+ }
+ })
+}
+
+Rental.current_title = function(title, columns, callback) {
+ var options = {
+ columns : ['name', 'phone', 'account_credit']
+ }
+ db.run("SELECT name, phone, account_credit FROM customers WHERE id IN (SELECT customer_id::int FROM rentals WHERE title = $1 AND returned_date IS null)", [title], function(error, customers) {
+ if(error) {
+ callback(error, undefined)
+ } else {
+ callback(null, customers)
+ }
+ })
+}
+
+Rental.current_id = function(id, column_name, callback) {
+ var options = {
+ order : column_name
+ }
+ db.run("SELECT title FROM movies WHERE title IN (SELECT title FROM rentals WHERE customer_id::int = $1 AND returned_date IS null)", [id], function(error, movies) {
+ if(error) {
+ callback(error, undefined)
+ } else {
+ callback(null, movies)
+ }
+ })
+}
+
+Rental.history_title = function(title, column_name, callback) {
+ db.run("SELECT name, phone, account_credit FROM customers WHERE id IN (SELECT customer_id::int FROM rentals WHERE title = $1 AND returned_date IS NOT null)", [title], function(error, customer_ids) {
+ if(error) {
+ callback(error, undefined)
+ } else {
+ Customer.find_id(customer_ids, column_name)
+ callback(null, customer_ids)
+ }
+ })
+}
+
+Rental.history_cust_id = function(id, column_name, columns, callback) {
+ db.run("SELECT title FROM rentals WHERE customer_id = $1 AND returned_date IS NOT null", [id], function(error, customer_ids) {
+ if(error) {
+ callback(error, undefined)
+ } else {
+ Customer.find_id(customer_ids, column_name)
+ callback(null, customer_ids)
+ }
+ })
+}
+
+module.exports = Rental
+ |
+
+
+
+
+
+
+
+
+
+
diff --git a/coverage/lcov-report/VideoStoreAPI/routes/index.html b/coverage/lcov-report/VideoStoreAPI/routes/index.html
new file mode 100644
index 000000000..369ef5218
--- /dev/null
+++ b/coverage/lcov-report/VideoStoreAPI/routes/index.html
@@ -0,0 +1,106 @@
+
+
+
+ Code coverage report for VideoStoreAPI/routes/
+
+
+
+
+
+
+
+
+
+
+ all files VideoStoreAPI/routes/
+
+
+
+ 62.5%
+ Statements
+ 25/40
+
+
+ 100%
+ Branches
+ 0/0
+
+
+ 0%
+ Functions
+ 0/15
+
+
+ 62.5%
+ Lines
+ 25/40
+
+
+
+
+
+
+
+
+ | File |
+ |
+ Statements |
+ |
+ Branches |
+ |
+ Functions |
+ |
+ Lines |
+ |
+
+
+
+ | index.js |
+ |
+ 58.82% |
+ 20/34 |
+ 100% |
+ 0/0 |
+ 0% |
+ 0/14 |
+ 58.82% |
+ 20/34 |
+
+
+
+ | zomg.js |
+ |
+ 83.33% |
+ 5/6 |
+ 100% |
+ 0/0 |
+ 0% |
+ 0/1 |
+ 83.33% |
+ 5/6 |
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/coverage/lcov-report/VideoStoreAPI/routes/index.js.html b/coverage/lcov-report/VideoStoreAPI/routes/index.js.html
new file mode 100644
index 000000000..ad37764a9
--- /dev/null
+++ b/coverage/lcov-report/VideoStoreAPI/routes/index.js.html
@@ -0,0 +1,284 @@
+
+
+
+ Code coverage report for VideoStoreAPI/routes/index.js
+
+
+
+
+
+
+
+
+
+
+
+
+ 58.82%
+ Statements
+ 20/34
+
+
+ 100%
+ Branches
+ 0/0
+
+
+ 0%
+ Functions
+ 0/14
+
+
+ 58.82%
+ Lines
+ 20/34
+
+
+
+
+
+| 1
+2
+3
+4
+5
+6
+7
+8
+9
+10
+11
+12
+13
+14
+15
+16
+17
+18
+19
+20
+21
+22
+23
+24
+25
+26
+27
+28
+29
+30
+31
+32
+33
+34
+35
+36
+37
+38
+39
+40
+41
+42
+43
+44
+45
+46
+47
+48
+49
+50
+51
+52
+53
+54
+55
+56
+57
+58
+59
+60
+61
+62
+63
+64
+65
+66
+67
+68
+69
+70
+71
+72
+73
+74 | 1×
+1×
+1×
+1×
+1×
+
+1×
+
+
+
+1×
+
+
+
+1×
+
+
+
+1×
+
+
+
+
+1×
+
+
+
+1×
+
+
+
+1×
+
+
+
+1×
+
+
+
+1×
+
+
+
+
+
+1×
+
+
+
+
+1×
+
+
+
+
+1×
+
+
+
+
+1×
+
+
+
+
+1×
+
+
+
+
+
+
+1×
+ | var express = require('express')
+var router = express.Router()
+var movies_controller = require('../controllers/movies_controller')
+var customers_controller = require('../controllers/customers_controller')
+var rentals_controller = require('../controllers/rentals_controller')
+
+router.get('/', function(req, res, next) {
+ res.status(200).json({whatevs: 'whatevs!!!'})
+})
+
+router.get('/movies', function(req, res, next) {
+ movies_controller.index(req, res, next)
+})
+
+router.get('/movies/sort/:column_name', function(req, res, next) {
+ movies_controller.sort(req, res, next)
+})
+
+router.get('/movies/:title/current',
+function(req, res, next) {
+ movies_controller.current(req, res, next)
+})
+
+router.get('/movies/:title/history/sort/:column_name',function(req, res, next){
+ movies_controller.history(req, res, next)
+})
+
+router.get('/customers', function(req, res, next){
+ customers_controller.index(req, res, next)
+})
+
+router.get('/customers/sort/:column_name', function(req, res, next) {
+ customers_controller.sort(req, res, next)
+})
+
+router.get('/customers/:id/current', function(req, res, next){
+ customers_controller.current(req, res, next)
+})
+
+router.get('/customers/:id/history',
+function(req, res, next) {
+ customers_controller.history(req, res, next)
+})
+
+//TO DO
+router.get('/rentals/:title',
+function(req, res, next) {
+ rentals_controller.view(req, res, next)
+})
+
+router.get('/rentals/:title/customers',
+function(req, res, next) {
+ rentals_controller.customers(req, res, next)
+})
+
+router.get('/rentals/:title/check-out/:id',
+function(req, res, next) {
+ rentals_controller.check-out(req, res, next)
+})
+
+router.get('/rentals/:title/return/:id',
+function(req, res, next) {
+ rentals_controller.return(req, res, next)
+})
+
+router.get('/rentals/overdue',
+function(req, res, next) {
+ rentals_controller.overdue(req, res, next)
+})
+
+
+
+module.exports = router
+ |
+
+
+
+
+
+
+
+
+
+
diff --git a/coverage/lcov-report/VideoStoreAPI/routes/zomg.js.html b/coverage/lcov-report/VideoStoreAPI/routes/zomg.js.html
new file mode 100644
index 000000000..414ba745a
--- /dev/null
+++ b/coverage/lcov-report/VideoStoreAPI/routes/zomg.js.html
@@ -0,0 +1,167 @@
+
+
+
+ Code coverage report for VideoStoreAPI/routes/zomg.js
+
+
+
+
+
+
+
+
+
+
+
+
+ 83.33%
+ Statements
+ 5/6
+
+
+ 100%
+ Branches
+ 0/0
+
+
+ 0%
+ Functions
+ 0/1
+
+
+ 83.33%
+ Lines
+ 5/6
+
+
+
+
+
+| 1
+2
+3
+4
+5
+6
+7
+8
+9
+10
+11
+12
+13
+14
+15
+16
+17
+18
+19
+20
+21
+22
+23
+24
+25
+26
+27
+28
+29
+30
+31
+32
+33
+34
+35 |
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+1×
+1×
+1×
+
+
+1×
+
+
+
+1×
+ | // Needed API endpoints w/HTTP verbs
+//
+// GET (/customers)
+//
+// GET (/customers/sort/name?n=10&p=2)
+// name (n)
+// registered_at (r)
+// postal_code (p)
+// GET (/customers/:id/current)
+// GET (/customers/:id/history)
+//
+// GET (/movies)
+// GET (/movies/sort/release-date?n=5&p=1)
+// title
+// release_date
+// GET (/movies/:title/current)
+// GET (/movies/:title/history/sort/name)
+//
+// GET (/rentals/:title)
+// GET (/rentals/:title/customers)
+// UPDATE (/rentals/:id/:title/check-out)
+// UPDATE (/rentals/:id/:title/return)
+// GET (/rentals/overdue)
+
+var express = require('express');
+var router = express.Router();
+var locals = {}
+
+/* GET home page. */
+router.get('/', function(req, res, next) {
+ res.status(200).json({whatevs: 'zomg!!!'})
+});
+
+module.exports = router;
+ |
+
+
+
+
+
+
+
+
+
+
diff --git a/coverage/lcov-report/base.css b/coverage/lcov-report/base.css
new file mode 100644
index 000000000..29737bcb0
--- /dev/null
+++ b/coverage/lcov-report/base.css
@@ -0,0 +1,213 @@
+body, html {
+ margin:0; padding: 0;
+ height: 100%;
+}
+body {
+ font-family: Helvetica Neue, Helvetica, Arial;
+ font-size: 14px;
+ color:#333;
+}
+.small { font-size: 12px; }
+*, *:after, *:before {
+ -webkit-box-sizing:border-box;
+ -moz-box-sizing:border-box;
+ box-sizing:border-box;
+ }
+h1 { font-size: 20px; margin: 0;}
+h2 { font-size: 14px; }
+pre {
+ font: 12px/1.4 Consolas, "Liberation Mono", Menlo, Courier, monospace;
+ margin: 0;
+ padding: 0;
+ -moz-tab-size: 2;
+ -o-tab-size: 2;
+ tab-size: 2;
+}
+a { color:#0074D9; text-decoration:none; }
+a:hover { text-decoration:underline; }
+.strong { font-weight: bold; }
+.space-top1 { padding: 10px 0 0 0; }
+.pad2y { padding: 20px 0; }
+.pad1y { padding: 10px 0; }
+.pad2x { padding: 0 20px; }
+.pad2 { padding: 20px; }
+.pad1 { padding: 10px; }
+.space-left2 { padding-left:55px; }
+.space-right2 { padding-right:20px; }
+.center { text-align:center; }
+.clearfix { display:block; }
+.clearfix:after {
+ content:'';
+ display:block;
+ height:0;
+ clear:both;
+ visibility:hidden;
+ }
+.fl { float: left; }
+@media only screen and (max-width:640px) {
+ .col3 { width:100%; max-width:100%; }
+ .hide-mobile { display:none!important; }
+}
+
+.quiet {
+ color: #7f7f7f;
+ color: rgba(0,0,0,0.5);
+}
+.quiet a { opacity: 0.7; }
+
+.fraction {
+ font-family: Consolas, 'Liberation Mono', Menlo, Courier, monospace;
+ font-size: 10px;
+ color: #555;
+ background: #E8E8E8;
+ padding: 4px 5px;
+ border-radius: 3px;
+ vertical-align: middle;
+}
+
+div.path a:link, div.path a:visited { color: #333; }
+table.coverage {
+ border-collapse: collapse;
+ margin: 10px 0 0 0;
+ padding: 0;
+}
+
+table.coverage td {
+ margin: 0;
+ padding: 0;
+ vertical-align: top;
+}
+table.coverage td.line-count {
+ text-align: right;
+ padding: 0 5px 0 20px;
+}
+table.coverage td.line-coverage {
+ text-align: right;
+ padding-right: 10px;
+ min-width:20px;
+}
+
+table.coverage td span.cline-any {
+ display: inline-block;
+ padding: 0 5px;
+ width: 100%;
+}
+.missing-if-branch {
+ display: inline-block;
+ margin-right: 5px;
+ border-radius: 3px;
+ position: relative;
+ padding: 0 4px;
+ background: #333;
+ color: yellow;
+}
+
+.skip-if-branch {
+ display: none;
+ margin-right: 10px;
+ position: relative;
+ padding: 0 4px;
+ background: #ccc;
+ color: white;
+}
+.missing-if-branch .typ, .skip-if-branch .typ {
+ color: inherit !important;
+}
+.coverage-summary {
+ border-collapse: collapse;
+ width: 100%;
+}
+.coverage-summary tr { border-bottom: 1px solid #bbb; }
+.keyline-all { border: 1px solid #ddd; }
+.coverage-summary td, .coverage-summary th { padding: 10px; }
+.coverage-summary tbody { border: 1px solid #bbb; }
+.coverage-summary td { border-right: 1px solid #bbb; }
+.coverage-summary td:last-child { border-right: none; }
+.coverage-summary th {
+ text-align: left;
+ font-weight: normal;
+ white-space: nowrap;
+}
+.coverage-summary th.file { border-right: none !important; }
+.coverage-summary th.pct { }
+.coverage-summary th.pic,
+.coverage-summary th.abs,
+.coverage-summary td.pct,
+.coverage-summary td.abs { text-align: right; }
+.coverage-summary td.file { white-space: nowrap; }
+.coverage-summary td.pic { min-width: 120px !important; }
+.coverage-summary tfoot td { }
+
+.coverage-summary .sorter {
+ height: 10px;
+ width: 7px;
+ display: inline-block;
+ margin-left: 0.5em;
+ background: url(sort-arrow-sprite.png) no-repeat scroll 0 0 transparent;
+}
+.coverage-summary .sorted .sorter {
+ background-position: 0 -20px;
+}
+.coverage-summary .sorted-desc .sorter {
+ background-position: 0 -10px;
+}
+.status-line { height: 10px; }
+/* dark red */
+.red.solid, .status-line.low, .low .cover-fill { background:#C21F39 }
+.low .chart { border:1px solid #C21F39 }
+/* medium red */
+.cstat-no, .fstat-no, .cbranch-no, .cbranch-no { background:#F6C6CE }
+/* light red */
+.low, .cline-no { background:#FCE1E5 }
+/* light green */
+.high, .cline-yes { background:rgb(230,245,208) }
+/* medium green */
+.cstat-yes { background:rgb(161,215,106) }
+/* dark green */
+.status-line.high, .high .cover-fill { background:rgb(77,146,33) }
+.high .chart { border:1px solid rgb(77,146,33) }
+/* dark yellow (gold) */
+.medium .chart { border:1px solid #f9cd0b; }
+.status-line.medium, .medium .cover-fill { background: #f9cd0b; }
+/* light yellow */
+.medium { background: #fff4c2; }
+/* light gray */
+span.cline-neutral { background: #eaeaea; }
+
+.cbranch-no { background: yellow !important; color: #111; }
+
+.cstat-skip { background: #ddd; color: #111; }
+.fstat-skip { background: #ddd; color: #111 !important; }
+.cbranch-skip { background: #ddd !important; color: #111; }
+
+
+.cover-fill, .cover-empty {
+ display:inline-block;
+ height: 12px;
+}
+.chart {
+ line-height: 0;
+}
+.cover-empty {
+ background: white;
+}
+.cover-full {
+ border-right: none !important;
+}
+pre.prettyprint {
+ border: none !important;
+ padding: 0 !important;
+ margin: 0 !important;
+}
+.com { color: #999 !important; }
+.ignore-none { color: #999; font-weight: normal; }
+
+.wrapper {
+ min-height: 100%;
+ height: auto !important;
+ height: 100%;
+ margin: 0 auto -48px;
+}
+.footer, .push {
+ height: 48px;
+}
diff --git a/coverage/lcov-report/index.html b/coverage/lcov-report/index.html
new file mode 100644
index 000000000..b25aa675f
--- /dev/null
+++ b/coverage/lcov-report/index.html
@@ -0,0 +1,132 @@
+
+
+
+ Code coverage report for All files
+
+
+
+
+
+
+
+
+
+
+ /
+
+
+
+ 43.3%
+ Statements
+ 97/224
+
+
+ 7.58%
+ Branches
+ 5/66
+
+
+ 9.52%
+ Functions
+ 6/63
+
+
+ 43.3%
+ Lines
+ 97/224
+
+
+
+
+
+
+
+
+ | File |
+ |
+ Statements |
+ |
+ Branches |
+ |
+ Functions |
+ |
+ Lines |
+ |
+
+
+
+ | VideoStoreAPI/ |
+ |
+ 75.76% |
+ 25/33 |
+ 16.67% |
+ 1/6 |
+ 0% |
+ 0/3 |
+ 75.76% |
+ 25/33 |
+
+
+
+ | VideoStoreAPI/controllers/ |
+ |
+ 19.4% |
+ 13/67 |
+ 0% |
+ 0/18 |
+ 0% |
+ 0/18 |
+ 19.4% |
+ 13/67 |
+
+
+
+ | VideoStoreAPI/models/ |
+ |
+ 40.48% |
+ 34/84 |
+ 9.52% |
+ 4/42 |
+ 22.22% |
+ 6/27 |
+ 40.48% |
+ 34/84 |
+
+
+
+ | VideoStoreAPI/routes/ |
+ |
+ 62.5% |
+ 25/40 |
+ 100% |
+ 0/0 |
+ 0% |
+ 0/15 |
+ 62.5% |
+ 25/40 |
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/coverage/lcov-report/prettify.css b/coverage/lcov-report/prettify.css
new file mode 100644
index 000000000..b317a7cda
--- /dev/null
+++ b/coverage/lcov-report/prettify.css
@@ -0,0 +1 @@
+.pln{color:#000}@media screen{.str{color:#080}.kwd{color:#008}.com{color:#800}.typ{color:#606}.lit{color:#066}.pun,.opn,.clo{color:#660}.tag{color:#008}.atn{color:#606}.atv{color:#080}.dec,.var{color:#606}.fun{color:red}}@media print,projection{.str{color:#060}.kwd{color:#006;font-weight:bold}.com{color:#600;font-style:italic}.typ{color:#404;font-weight:bold}.lit{color:#044}.pun,.opn,.clo{color:#440}.tag{color:#006;font-weight:bold}.atn{color:#404}.atv{color:#060}}pre.prettyprint{padding:2px;border:1px solid #888}ol.linenums{margin-top:0;margin-bottom:0}li.L0,li.L1,li.L2,li.L3,li.L5,li.L6,li.L7,li.L8{list-style-type:none}li.L1,li.L3,li.L5,li.L7,li.L9{background:#eee}
diff --git a/coverage/lcov-report/prettify.js b/coverage/lcov-report/prettify.js
new file mode 100644
index 000000000..ef51e0386
--- /dev/null
+++ b/coverage/lcov-report/prettify.js
@@ -0,0 +1 @@
+window.PR_SHOULD_USE_CONTINUATION=true;(function(){var h=["break,continue,do,else,for,if,return,while"];var u=[h,"auto,case,char,const,default,double,enum,extern,float,goto,int,long,register,short,signed,sizeof,static,struct,switch,typedef,union,unsigned,void,volatile"];var p=[u,"catch,class,delete,false,import,new,operator,private,protected,public,this,throw,true,try,typeof"];var l=[p,"alignof,align_union,asm,axiom,bool,concept,concept_map,const_cast,constexpr,decltype,dynamic_cast,explicit,export,friend,inline,late_check,mutable,namespace,nullptr,reinterpret_cast,static_assert,static_cast,template,typeid,typename,using,virtual,where"];var x=[p,"abstract,boolean,byte,extends,final,finally,implements,import,instanceof,null,native,package,strictfp,super,synchronized,throws,transient"];var R=[x,"as,base,by,checked,decimal,delegate,descending,dynamic,event,fixed,foreach,from,group,implicit,in,interface,internal,into,is,lock,object,out,override,orderby,params,partial,readonly,ref,sbyte,sealed,stackalloc,string,select,uint,ulong,unchecked,unsafe,ushort,var"];var r="all,and,by,catch,class,else,extends,false,finally,for,if,in,is,isnt,loop,new,no,not,null,of,off,on,or,return,super,then,true,try,unless,until,when,while,yes";var w=[p,"debugger,eval,export,function,get,null,set,undefined,var,with,Infinity,NaN"];var s="caller,delete,die,do,dump,elsif,eval,exit,foreach,for,goto,if,import,last,local,my,next,no,our,print,package,redo,require,sub,undef,unless,until,use,wantarray,while,BEGIN,END";var I=[h,"and,as,assert,class,def,del,elif,except,exec,finally,from,global,import,in,is,lambda,nonlocal,not,or,pass,print,raise,try,with,yield,False,True,None"];var f=[h,"alias,and,begin,case,class,def,defined,elsif,end,ensure,false,in,module,next,nil,not,or,redo,rescue,retry,self,super,then,true,undef,unless,until,when,yield,BEGIN,END"];var H=[h,"case,done,elif,esac,eval,fi,function,in,local,set,then,until"];var A=[l,R,w,s+I,f,H];var e=/^(DIR|FILE|vector|(de|priority_)?queue|list|stack|(const_)?iterator|(multi)?(set|map)|bitset|u?(int|float)\d*)/;var C="str";var z="kwd";var j="com";var O="typ";var G="lit";var L="pun";var F="pln";var m="tag";var E="dec";var J="src";var P="atn";var n="atv";var N="nocode";var M="(?:^^\\.?|[+-]|\\!|\\!=|\\!==|\\#|\\%|\\%=|&|&&|&&=|&=|\\(|\\*|\\*=|\\+=|\\,|\\-=|\\->|\\/|\\/=|:|::|\\;|<|<<|<<=|<=|=|==|===|>|>=|>>|>>=|>>>|>>>=|\\?|\\@|\\[|\\^|\\^=|\\^\\^|\\^\\^=|\\{|\\||\\|=|\\|\\||\\|\\|=|\\~|break|case|continue|delete|do|else|finally|instanceof|return|throw|try|typeof)\\s*";function k(Z){var ad=0;var S=false;var ac=false;for(var V=0,U=Z.length;V122)){if(!(al<65||ag>90)){af.push([Math.max(65,ag)|32,Math.min(al,90)|32])}if(!(al<97||ag>122)){af.push([Math.max(97,ag)&~32,Math.min(al,122)&~32])}}}}af.sort(function(av,au){return(av[0]-au[0])||(au[1]-av[1])});var ai=[];var ap=[NaN,NaN];for(var ar=0;arat[0]){if(at[1]+1>at[0]){an.push("-")}an.push(T(at[1]))}}an.push("]");return an.join("")}function W(al){var aj=al.source.match(new RegExp("(?:\\[(?:[^\\x5C\\x5D]|\\\\[\\s\\S])*\\]|\\\\u[A-Fa-f0-9]{4}|\\\\x[A-Fa-f0-9]{2}|\\\\[0-9]+|\\\\[^ux0-9]|\\(\\?[:!=]|[\\(\\)\\^]|[^\\x5B\\x5C\\(\\)\\^]+)","g"));var ah=aj.length;var an=[];for(var ak=0,am=0;ak=2&&ai==="["){aj[ak]=X(ag)}else{if(ai!=="\\"){aj[ak]=ag.replace(/[a-zA-Z]/g,function(ao){var ap=ao.charCodeAt(0);return"["+String.fromCharCode(ap&~32,ap|32)+"]"})}}}}return aj.join("")}var aa=[];for(var V=0,U=Z.length;V=0;){S[ac.charAt(ae)]=Y}}var af=Y[1];var aa=""+af;if(!ag.hasOwnProperty(aa)){ah.push(af);ag[aa]=null}}ah.push(/[\0-\uffff]/);V=k(ah)})();var X=T.length;var W=function(ah){var Z=ah.sourceCode,Y=ah.basePos;var ad=[Y,F];var af=0;var an=Z.match(V)||[];var aj={};for(var ae=0,aq=an.length;ae=5&&"lang-"===ap.substring(0,5);if(am&&!(ai&&typeof ai[1]==="string")){am=false;ap=J}if(!am){aj[ag]=ap}}var ab=af;af+=ag.length;if(!am){ad.push(Y+ab,ap)}else{var al=ai[1];var ak=ag.indexOf(al);var ac=ak+al.length;if(ai[2]){ac=ag.length-ai[2].length;ak=ac-al.length}var ar=ap.substring(5);B(Y+ab,ag.substring(0,ak),W,ad);B(Y+ab+ak,al,q(ar,al),ad);B(Y+ab+ac,ag.substring(ac),W,ad)}}ah.decorations=ad};return W}function i(T){var W=[],S=[];if(T.tripleQuotedStrings){W.push([C,/^(?:\'\'\'(?:[^\'\\]|\\[\s\S]|\'{1,2}(?=[^\']))*(?:\'\'\'|$)|\"\"\"(?:[^\"\\]|\\[\s\S]|\"{1,2}(?=[^\"]))*(?:\"\"\"|$)|\'(?:[^\\\']|\\[\s\S])*(?:\'|$)|\"(?:[^\\\"]|\\[\s\S])*(?:\"|$))/,null,"'\""])}else{if(T.multiLineStrings){W.push([C,/^(?:\'(?:[^\\\']|\\[\s\S])*(?:\'|$)|\"(?:[^\\\"]|\\[\s\S])*(?:\"|$)|\`(?:[^\\\`]|\\[\s\S])*(?:\`|$))/,null,"'\"`"])}else{W.push([C,/^(?:\'(?:[^\\\'\r\n]|\\.)*(?:\'|$)|\"(?:[^\\\"\r\n]|\\.)*(?:\"|$))/,null,"\"'"])}}if(T.verbatimStrings){S.push([C,/^@\"(?:[^\"]|\"\")*(?:\"|$)/,null])}var Y=T.hashComments;if(Y){if(T.cStyleComments){if(Y>1){W.push([j,/^#(?:##(?:[^#]|#(?!##))*(?:###|$)|.*)/,null,"#"])}else{W.push([j,/^#(?:(?:define|elif|else|endif|error|ifdef|include|ifndef|line|pragma|undef|warning)\b|[^\r\n]*)/,null,"#"])}S.push([C,/^<(?:(?:(?:\.\.\/)*|\/?)(?:[\w-]+(?:\/[\w-]+)+)?[\w-]+\.h|[a-z]\w*)>/,null])}else{W.push([j,/^#[^\r\n]*/,null,"#"])}}if(T.cStyleComments){S.push([j,/^\/\/[^\r\n]*/,null]);S.push([j,/^\/\*[\s\S]*?(?:\*\/|$)/,null])}if(T.regexLiterals){var X=("/(?=[^/*])(?:[^/\\x5B\\x5C]|\\x5C[\\s\\S]|\\x5B(?:[^\\x5C\\x5D]|\\x5C[\\s\\S])*(?:\\x5D|$))+/");S.push(["lang-regex",new RegExp("^"+M+"("+X+")")])}var V=T.types;if(V){S.push([O,V])}var U=(""+T.keywords).replace(/^ | $/g,"");if(U.length){S.push([z,new RegExp("^(?:"+U.replace(/[\s,]+/g,"|")+")\\b"),null])}W.push([F,/^\s+/,null," \r\n\t\xA0"]);S.push([G,/^@[a-z_$][a-z_$@0-9]*/i,null],[O,/^(?:[@_]?[A-Z]+[a-z][A-Za-z_$@0-9]*|\w+_t\b)/,null],[F,/^[a-z_$][a-z_$@0-9]*/i,null],[G,new RegExp("^(?:0x[a-f0-9]+|(?:\\d(?:_\\d+)*\\d*(?:\\.\\d*)?|\\.\\d\\+)(?:e[+\\-]?\\d+)?)[a-z]*","i"),null,"0123456789"],[F,/^\\[\s\S]?/,null],[L,/^.[^\s\w\.$@\'\"\`\/\#\\]*/,null]);return g(W,S)}var K=i({keywords:A,hashComments:true,cStyleComments:true,multiLineStrings:true,regexLiterals:true});function Q(V,ag){var U=/(?:^|\s)nocode(?:\s|$)/;var ab=/\r\n?|\n/;var ac=V.ownerDocument;var S;if(V.currentStyle){S=V.currentStyle.whiteSpace}else{if(window.getComputedStyle){S=ac.defaultView.getComputedStyle(V,null).getPropertyValue("white-space")}}var Z=S&&"pre"===S.substring(0,3);var af=ac.createElement("LI");while(V.firstChild){af.appendChild(V.firstChild)}var W=[af];function ae(al){switch(al.nodeType){case 1:if(U.test(al.className)){break}if("BR"===al.nodeName){ad(al);if(al.parentNode){al.parentNode.removeChild(al)}}else{for(var an=al.firstChild;an;an=an.nextSibling){ae(an)}}break;case 3:case 4:if(Z){var am=al.nodeValue;var aj=am.match(ab);if(aj){var ai=am.substring(0,aj.index);al.nodeValue=ai;var ah=am.substring(aj.index+aj[0].length);if(ah){var ak=al.parentNode;ak.insertBefore(ac.createTextNode(ah),al.nextSibling)}ad(al);if(!ai){al.parentNode.removeChild(al)}}}break}}function ad(ak){while(!ak.nextSibling){ak=ak.parentNode;if(!ak){return}}function ai(al,ar){var aq=ar?al.cloneNode(false):al;var ao=al.parentNode;if(ao){var ap=ai(ao,1);var an=al.nextSibling;ap.appendChild(aq);for(var am=an;am;am=an){an=am.nextSibling;ap.appendChild(am)}}return aq}var ah=ai(ak.nextSibling,0);for(var aj;(aj=ah.parentNode)&&aj.nodeType===1;){ah=aj}W.push(ah)}for(var Y=0;Y=S){ah+=2}if(V>=ap){Z+=2}}}var t={};function c(U,V){for(var S=V.length;--S>=0;){var T=V[S];if(!t.hasOwnProperty(T)){t[T]=U}else{if(window.console){console.warn("cannot override language handler %s",T)}}}}function q(T,S){if(!(T&&t.hasOwnProperty(T))){T=/^\s*]*(?:>|$)/],[j,/^<\!--[\s\S]*?(?:-\->|$)/],["lang-",/^<\?([\s\S]+?)(?:\?>|$)/],["lang-",/^<%([\s\S]+?)(?:%>|$)/],[L,/^(?:<[%?]|[%?]>)/],["lang-",/^]*>([\s\S]+?)<\/xmp\b[^>]*>/i],["lang-js",/^
+
+
+
+
+
+
+
+
+
Hello, world!
+
This is a simple hero unit, a simple jumbotron-style component for calling extra attention to featured content or information.
+
Learn more
+
+
+
+