diff --git a/LICENSE b/LICENSE
index 3f05397..c6e5dce 100644
--- a/LICENSE
+++ b/LICENSE
@@ -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
@@ -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.
+
diff --git a/README.md b/README.md
index cf296ed..97c62d8 100644
--- a/README.md
+++ b/README.md
@@ -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
+=====================
+
+[](http://ipn.io)
+[](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.
+
+
+
+# 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
diff --git a/img/badge.png b/img/badge.png
new file mode 100644
index 0000000..07f7327
Binary files /dev/null and b/img/badge.png differ
diff --git a/img/badge.sketch b/img/badge.sketch
new file mode 100644
index 0000000..985a835
Binary files /dev/null and b/img/badge.sketch differ
diff --git a/img/badge.svg b/img/badge.svg
new file mode 100644
index 0000000..43b16d1
--- /dev/null
+++ b/img/badge.svg
@@ -0,0 +1,25 @@
+
+
\ No newline at end of file
diff --git a/package.json b/package.json
new file mode 100644
index 0000000..e5c34a4
--- /dev/null
+++ b/package.json
@@ -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 ",
+ "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"
+ }
+}
diff --git a/tests/base-test.js b/tests/base-test.js
new file mode 100644
index 0000000..3568674
--- /dev/null
+++ b/tests/base-test.js
@@ -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()
+ })
+ })
+}
diff --git a/tests/index.js b/tests/index.js
new file mode 100644
index 0000000..3c21b14
--- /dev/null
+++ b/tests/index.js
@@ -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)
+}