Recents in Beach

Rahasia Uang Mengalir Dari Internet Hanya Dalam 30 menit!

Continues Integration Menggunakan Travis CI dan Github Part 3

Continues Integration Menggunakan Travis CI dan Github Part 3 - Hallo sahabat Dunia Internet, Pada Artikel yang anda baca kali ini dengan judul Continues Integration Menggunakan Travis CI dan Github Part 3, kami telah mempersiapkan artikel ini dengan baik untuk anda baca dan ambil informasi didalamnya. mudah-mudahan isi postingan Artikel Agile software development, Artikel Continues Integration, yang kami tulis ini dapat anda pahami. baiklah, selamat membaca.

Judul : Continues Integration Menggunakan Travis CI dan Github Part 3
link : Continues Integration Menggunakan Travis CI dan Github Part 3

Baca juga


Continues Integration Menggunakan Travis CI dan Github Part 3


Setelah sekian lama saya tidak update karna kesibukan akhirnya kali ini saya bisa update melanjutkan postingan sebelumnya :D.

Pada artikel sebelumnya yaitu Continues Integration Menggunakan Travis CI dan Github Part 2 kita telah membuat test untuk proyek yang akan dibuat, dan pada postingan kali ini kita akan menerapkan tes yang telah dibuat.


Menerapkan tes

Jalankan perintah berikut pada cmd/terminal untuk menginstall library yang kita gunakan untuk membuat server.

npm install express mongodb --save

Disini saya menggunakan express untuk mempermudah dalam pembuatan server dan mongodb database untuk menyimpan riwayat pencarian. Pada kasus ini saya menggunakan layanan mlab.com untuk bagian database mongodb. Anda dapat mendaftar di mlab.com kemudian membuat database dan user baru serta mengcopy mongodb uri, uri tersebut nantinya akan digunakan untuk autentikasi ke layanan mlab.
Mongodb URI


Sekarang buat file baru beri nama server.js dan copy koding berikut

const app = require('./app');
const http = require('http');
const port = process.env.PORT || 8080;
const server = http.createServer(app);

// memulai server dan mendengarkan pada port yang telah ditentukan
server.listen(port);
server.on('listening', function () {
console.log('server running and listening at port ' + port);
});
// mendengarkan event error yang terjadi di server
server.on('error', onError);

function onError(error) {
if (error.syscall !== 'listen') {
throw error;
}
const bind = typeof port === 'string' ? 'Pipe ' + port : 'Port ' + port;
switch (error.code) {
case 'EACCES':
console.error(bind + ' requires elevated privileges');
process.exit(1);
break;
case 'EADDRINUSE':
console.error(bind + ' is already in use');
process.exit(1);
break;
default:
throw error;
}
}

Selanjutnya buat file javascript baru beri nama app.js, pada file ini kita akan menginisialisasikan tiap route yang akan digunakan. Pertama-tama kita akan menginisilaisasikan express dan membuat halaman index.
const path = require('path');
// menginisialisasikan express framework
const express = require('express');
const app = express();
// megirimkan response file index.html ke sisi klien saat server diakses hanya menggunakan hostname
// http://expressjs.com/en/starter/basic-routing.html
app.get('/', function (req, res) {
res.sendFile(path.join(__dirname, 'index.html'));
});
Kemudian buat file html baru beri nama index.html dan copykan coding berikut.


Sekarang kita akan membuat API route untuk pencarian.
const path = require('path');
// menginisialisasikan express framework
const express = require('express');
const app = express();
const apiKey = process.env.GCS_API_KEY || 'GOOGLE_CUSTOM_SEARCH_API_KEY';
const baseUrl = 'https://www.googleapis.com/customsearch/v1?key=' + apiKey + '&searchType=image&cx=012158711088233114633:p02zzyrapyg&q=';
// megirimkan response file index.html ke sisi klien saat server diakses hanya menggunakan hostname
// http://expressjs.com/en/starter/basic-routing.html
app.get('/', function (req, res) {
res.sendFile(path.join(__dirname, 'index.html'));
});
// mengirimkan API response array dari Google Custom Search saat user mengakses url http://yourweb.com/anything
app.get('/:query', handleSearch);

function handleSearch(req, res) {
// mendapatkan url query paramater
const query = req.params.query;
const limit = req.query.limit || 10;
const startIndex = req.query.offset || 1;
// jika offset lebih dari 1 maka tambahkan offset dengan limit
if (startIndex > 1) startIndex = (startIndex * limit) - limit;
const url = baseUrl + query + '&num=' + limit + '&start=' + startIndex;
// mengirim http request ke Google Custom Search API
httpRequest(url).then(function (response) {
var history = {
"term": query,
"time": new Date().toLocaleString()
};
// Menyimpan query dan waktu ke database
if (query !== 'favicon.ico') {
db.save(history);
response = JSON.parse(response);
console.log('response', response);
// mengirimkan response dari Google Custom Search API ke klien
res.send(response.items.map(function (item) {
item.image.link = item.link;
return item.image;
}));
}
});
}

Sekarang buat file javascript baru beri nama httprequest.js kemudian copy koding berikut
const http = require('http');
const https = require('https');

module.exports = function (url, data) {
return new Promise(function(resolve, reject) {
if(url.startsWith('https://'))
https.get(url, function(response) {
console.log('statusCode:', response.statusCode);
// Continuously update stream with data
var body = ';
response.on('data', function (d) {
body += d.toString();
});
response.on('error', reject);
response.on('end', function () {
// Data reception is done, do whatever with it!
resolve(body);
});
}).on('error', reject);
if(url.startsWith('http://'))
http.get(url, function(response) {
console.log('statusCode:', response.statusCode);
// Continuously update stream with data
var body = ';
response.on('data', function (d) {
body += d.toString();
});
response.on('error', reject);
response.on('end', function () {
// Data reception is done, do whatever with it!
resolve(body);
});
}).on('error', reject);

});
}

Selanjutnya buat file javascript baru beri nama db.js.
const mongodb = require('mongodb');
const MongoClient = mongodb.MongoClient;
const url = process.env.MONGOLAB_URI || 'MONGODB_URI';

// Menggunakan metode connect untuk melakukan koneksi ke mlab.com
MongoClient.connect(url, function (err, db) {
if (err) {
console.log('Unable to connect to the mongoDB server. Error:', err);
} else {
console.log('Connection established to mongolab db');
db.createCollection("histories", {
capped: false,
size: 5242880,
max: 5000
}, function () {
//Close connection
db.close();
});

}
});

// menghapus data dari database
module.exports.deleteData = function (obj) {
MongoClient.connect(url, function (err, db) {
if (err)
throw new Error('Unable to connect to the mongoDB server. Error:', err);
var links = db.collection('histories');
links.remove(obj, function (err, result) {
if (err) throw err;
console.log('Deleted ' + result);
db.close();
});
});
}
// menyimpan data ke database
module.exports.save = function (obj) {
MongoClient.connect(url, function (err, db) {
if (err)
throw err;
var histories = db.collection('histories');
histories.save(obj, function (err, result) {
if (err) throw err;
console.log('Saved ' + result);
db.close();
});
})
}
// mendapatkan semua riwayat pencarian
module.exports.getHistory = function (req, res) {
MongoClient.connect(url, function (err, db) {
var histories = db.collection('histories');
histories.find({}, {}, {
"limit": 10,
"sort": {
"time": -1
}
}, function (err, history) {
if (err) return console.error(err);
history.toArray(function (err, result) {
if (err) throw err;
console.log(result);
res.send(result.map(function (arg) {
// Displays only the field we need to show.
return {
term: arg.term,
time: arg.time
};
}));
});
});
});
};

Sekarang jalankan tes kembali maka Anda akan melihat bahwa semua tes sudah berhasil.

Pada postingan selanjutnya kita akan mulai menggunakan Github dan Travis CI untuk melakukan Continues Integration.


Demikianlah Artikel Continues Integration Menggunakan Travis CI dan Github Part 3

Sekianlah artikel Continues Integration Menggunakan Travis CI dan Github Part 3 kali ini, mudah-mudahan bisa memberi manfaat untuk anda semua. baiklah, sampai jumpa di postingan artikel lainnya.

Anda sekarang membaca artikel Continues Integration Menggunakan Travis CI dan Github Part 3 dengan alamat link https://duniainternet66.blogspot.com/2017/12/continues-integration-menggunakan.html

Posting Komentar

0 Komentar