Skip to content
This repository has been archived by the owner on Mar 11, 2020. It is now read-only.

Commit

Permalink
first pass on this spec
Browse files Browse the repository at this point in the history
  • Loading branch information
daviddias committed Feb 20, 2018
1 parent 9c9ea94 commit 8a72f17
Show file tree
Hide file tree
Showing 8 changed files with 129 additions and 4 deletions.
5 changes: 3 additions & 2 deletions LICENSE
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
MIT License
The MIT License (MIT)

Copyright (c) 2018 libp2p
Copyright (c) 2018 David Dias

Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
Expand All @@ -19,3 +19,4 @@ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
SOFTWARE.

64 changes: 62 additions & 2 deletions README.md
Original file line number Diff line number Diff line change
@@ -1,2 +1,62 @@
# interface-content-routing
A test suite and interface you can use to implement a Content Routing for libp2p.
interface-content-routing
=====================

[![](https://img.shields.io/badge/made%20by-Protocol%20Labs-blue.svg?style=flat-square)](http://ipn.io)
[![](https://img.shields.io/badge/freenode-%23ipfs-blue.svg?style=flat-square)](http://webchat.freenode.net/?channels=%23ipfs)

> A test suite and interface you can use to implement a Content Routing module for libp2p.
The primary goal of this module is to enable developers to pick and swap their Content Routing module as they see fit for their libp2p installation, without having to go through shims or compatibility issues. This module and test suite were heavily inspired by abstract-blob-store and interface-stream-muxer.

Publishing a test suite as a module lets multiple modules all ensure compatibility since they use the same test suite.

The API is presented with both Node.js and Go primitives, however, there is not actual limitations for it to be extended for any other language, pushing forward the cross compatibility and interop through diferent stacks.

# Modules that implement the interface

- [JavaScript libp2p-kad-dht](https://github.com/libp2p/js-libp2p-kad-dht)
- [JavaScript libp2p-delegated-peer-routing](https://github.com/libp2p/js-libp2p-delegated-peer-routing)
- [JavaScript libp2p-kad-routing](https://github.com/libp2p/js-libp2p-kad-routing)

# Badge

Include this badge in your readme if you make a module that is compatible with the interface-content-routing API. You can validate this by running the tests.

![](https://raw.githubusercontent.com/libp2p/interface-content-routing/master/img/badge.png)

# How to use the battery of tests

## Node.js

```javascript
var tape = require('tape')
var tests = require('interface-content-routing/tests')
var yourImpl = require('../src')

var common = {
setup: function (t, cb) {
cb(null, yourImpl)
},
teardown: function (t, cb) {
cb()
}
}

tests(tape, common)
```

## Go

> WIP - The go-libp2p implementation does not have a test suite to be used, yet.
# API

A valid (read: that follows this abstraction) Peer Routing module must implement the following API.

### `.findProviders`

- `JavaScript` peerRouting.findProviders

### `.provide`

- `JavaScript` peerRouting.provide
Binary file added img/badge.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added img/badge.sketch
Binary file not shown.
25 changes: 25 additions & 0 deletions img/badge.svg
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
22 changes: 22 additions & 0 deletions package.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
{
"name": "interface-content-routing",
"version": "0.0.0",
"description": "A test suite and interface you can use to implement a Content Routing for libp2p.",
"repository": {
"type": "git",
"url": "https://github.com/libp2p/interface-content-routing.git"
},
"keywords": [
"IPFS"
],
"author": "David Dias <[email protected]>",
"license": "MIT",
"bugs": {
"url": "https://github.com/libp2p/interface-content-routing/issues"
},
"homepage": "https://github.com/libp2p/interface-content-routing",
"devDependencies": {},
"dependencies": {
"timed-tape": "^0.1.1"
}
}
10 changes: 10 additions & 0 deletions tests/base-test.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
'use strict'

module.exports.all = function (test, common) {
test('test', function (t) {
common.setup(test, function (err, pr) {
if (err) {}
common.teardown()
})
})
}
7 changes: 7 additions & 0 deletions tests/index.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
'use strict'
const timed = require('timed-tape')

module.exports = function (test, common) {
test = timed(test)
require('./base-test.js').all(test, common)
}

0 comments on commit 8a72f17

Please sign in to comment.