Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ozanturksever/connect-api-mocker
Connect middleware that creates mocks for REST APIs - Çakma REST API'ler yapmak için connect middleware
https://github.com/ozanturksever/connect-api-mocker
Last synced: 13 days ago
JSON representation
Connect middleware that creates mocks for REST APIs - Çakma REST API'ler yapmak için connect middleware
- Host: GitHub
- URL: https://github.com/ozanturksever/connect-api-mocker
- Owner: ozanturksever
- Created: 2013-08-19T18:12:50.000Z (over 11 years ago)
- Default Branch: master
- Last Pushed: 2013-08-19T18:41:57.000Z (over 11 years ago)
- Last Synced: 2024-11-08T09:21:51.474Z (2 months ago)
- Language: JavaScript
- Size: 43.9 KB
- Stars: 0
- Watchers: 2
- Forks: 3
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
connect-api-mocker
==================`connect-api-mocker`, REST API'lerle haberleşen web uygulamaları yaparken, uygulamayı REST API'nın sınırlılıklarından bağımsız olarak test edebilmek için, dosya sistemiyle sahte bir REST API sunmaya yarayan bir [connect.js](https://github.com/senchalabs/connect) middleware'ıdır.
## Kullanım
Bu middleware [Grunt](http://gruntjs.com) ile kolayca kullanılabilir. [grunt-contrib-connect](https://github.com/gruntjs/grunt-contrib-connect) eklentisi kurulduktan sonra, konfigürasyona api-mocker middleware'i aşağıdaki gibi eklendiğinde, projenin `mocks/api` klasörü, `/api` adresinden REST servisi gibi sunulmaya başlanacaktır:
```js
module.exports = function(grunt) {
var apiMocker = require('./lib/middlewares/api-mocker');grunt.loadNpmTasks('grunt-contrib-connect'); // Connect - Gelistirme sunucusu
// Project configuration.
grunt.initConfig({// Gelistirme sunucusu
connect: {
server: {
options: {
base: './build',
port: 9001,
middleware: function(connect, options) {var middlewares = [];
// mock/rest klasorunu sahte servis katmani olarak kullan
middlewares.push(apiMocker(
'/api',
'mocks/api'
));// Statik dosyalar
middlewares.push(connect.static(options.base));
middlewares.push(connect.static(__dirname));return middlewares;
}
}
}
}
});
}
```Daha sonra `grunt connect` komutuyla statik sunucu çalıştırıldığında `/api` adresi ile `mocks/api` klasörünün REST API olarak sunulduğu görülecektir.
## Klasör yapısı
REST servis URL'i ile aynı yapıda klasör yapısı oluşturularak, oluşturulan klasöre HTTP talep tipi ile aynı adda JSON dosyaları eklenerek bu adrese, bu tiplerde yapılan taleplere belirtilen JSON kaynaklarının gönderilmesi sağlanabilir.
Örnek REST servisi: `GET /api/messages`
Dosya sistemi yapısı:
```
_ api
\_ messages
\_ GET.json
```Örnek REST servisi: `GET /api/messages/1`
Dosya sistemi yapısı:
```
_ api
\_ messages
\_ 1
\_ GET.json
```Örnek REST servisi: `POST /api/messages/1`
Dosya sistemi yapısı:
```
_ api
\_ messages
\_ 1
\_ POST.json
```Örnek REST servisi: `DELETE /api/messages/1`
Dosya sistemi yapısı:
```
_ api
\_ messages
\_ 1
\_ DELETE.json
```## Hız limiti simülasyonu
api-mocker'ın 3. parametresi hız limitidir. Bu değer kilobit/saniye cinsindendir ve varsayılan olarak 0 yani limitsizdir. Düşük internet hızlarında uygulamanızın tepkisini ölçmek için bu özellik kullanılabilir.
Örnek grunt konfigürasyonu:
```js
...
middleware: function(connect, options) {var middlewares = [];
// mock/rest klasorunu sahte servis katmani olarak kullan
middlewares.push(apiMocker(
'/api',
'mocks/api',
50 // 50 kilobit/saniye hızda gönder
));
...
```