Skip to content
This repository was archived by the owner on Sep 28, 2021. It is now read-only.

chore: update to new multiformats #98

Merged
merged 3 commits into from
Jul 12, 2021
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
3 changes: 1 addition & 2 deletions .github/workflows/main.yml
Original file line number Diff line number Diff line change
Expand Up @@ -22,14 +22,13 @@ jobs:
strategy:
matrix:
os: [windows-latest, ubuntu-latest, macos-latest]
node: [14, 15]
node: [14, 16]
fail-fast: true
steps:
- uses: actions/checkout@v2
- uses: actions/setup-node@v1
with:
node-version: ${{ matrix.node }}
- run: npm install -g @mapbox/node-pre-gyp
- run: npm install
- run: npx aegir test -t node --cov --bail
- uses: codecov/codecov-action@v1
7 changes: 3 additions & 4 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -39,14 +39,13 @@
"it-reader": "^3.0.0",
"it-to-stream": "^1.0.0",
"mime-types": "^2.1.30",
"multihashes": "^4.0.2",
"multiformats": "^9.2.0",
"p-try-each": "^1.0.1"
},
"devDependencies": {
"aegir": "^33.1.2",
"cids": "^1.0.0",
"aegir": "^34.0.2",
"get-stream": "^6.0.0",
"ipfs": "^0.55.1",
"ipfs-core": "^0.8.0",
"ipfsd-ctl": "^8.0.2",
"it-all": "^1.0.5",
"path": "^0.12.7",
Expand Down
5 changes: 3 additions & 2 deletions src/resolver.js
Original file line number Diff line number Diff line change
@@ -1,7 +1,6 @@
'use strict'

const pTryEach = require('p-try-each')
const mh = require('multihashes')
const debug = require('debug')
const log = debug('jsipfs:http:response:resolver')
log.error = debug('jsipfs:http:response:resolver:error')
Expand Down Expand Up @@ -64,7 +63,9 @@ const multihash = async (ipfs, path) => {
// (left for backward-compatibility)
const result = await cid(ipfs, path)

return { multihash: mh.toB58String(result.cid.multihash) }
return {
multihash: result.cid.toString()
}
}

module.exports = {
Expand Down
17 changes: 8 additions & 9 deletions test/index.spec.js
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,6 @@ const { expect } = require('aegir/utils/chai')
const loadFixture = require('aegir/utils/fixtures')
const { createFactory } = require('ipfsd-ctl')
const getStream = require('get-stream')
const CID = require('cids')
const all = require('it-all')
const uint8ArrayToString = require('uint8arrays/to-string')

Expand All @@ -16,7 +15,7 @@ const makeWebResponseEnv = require('./utils/web-response-env')
const factory = createFactory({
test: true,
type: 'proc',
ipfsModule: require('ipfs')
ipfsModule: require('ipfs-core')
})

describe('resolve file (CIDv0)', function () {
Expand All @@ -35,7 +34,7 @@ describe('resolve file (CIDv0)', function () {
ipfs = ipfsd.api

const retrievedFile = await ipfs.add(file.data, { cidVersion: 0 })
expect(retrievedFile.cid).to.deep.equal(new CID(file.cid))
expect(retrievedFile.cid.toString()).to.equal(file.cid)
expect(retrievedFile.size, 'ipfs.add result size should not be smaller than input buffer').greaterThan(file.data.length)
})

Expand Down Expand Up @@ -71,7 +70,7 @@ describe('resolve file (CIDv1)', function () {
ipfs = ipfsd.api

const retrievedFile = await ipfs.add(file.data, { cidVersion: 1 })
expect(retrievedFile.cid).to.deep.equal(new CID(file.cid))
expect(retrievedFile.cid.toString()).to.equal(file.cid)
expect(retrievedFile.size, 'ipfs.add result size should equal input buffer').to.equal(file.data.length)
})

Expand Down Expand Up @@ -123,7 +122,7 @@ describe('resolve directory (CIDv0)', function () {
const root = res[res.length - 1]

expect(root.path).to.equal('test-folder')
expect(root.cid).to.deep.equal(new CID(directory.cid))
expect(root.cid.toString()).to.equal(directory.cid)

expect(res[0].size, 'ipfs.add 1st result size should not be smaller than 1st input buffer').greaterThan(dirs[0].content.length)
expect(res[1].size, 'ipfs.add 2nd result size should not be smaller than 2nd input buffer').greaterThan(dirs[1].content.length)
Expand Down Expand Up @@ -191,7 +190,7 @@ describe('resolve directory (CIDv1)', function () {
expect(root.path).to.equal('test-folder')
// expect(res[0].size, 'ipfs.files.add 1st result size should not be smaller than 1st input buffer').greaterThan(dirs[0].content.length)
// expect(res[1].size, 'ipfs.files.add 2nd result size should not be smaller than 2nd input buffer').greaterThan(dirs[1].content.length)
expect(root.cid).to.deep.equal(new CID(directory.cid))
expect(root.cid.toString()).to.equal(directory.cid)
})

after(() => factory.clean())
Expand Down Expand Up @@ -257,7 +256,7 @@ describe('resolve web page (CIDv0)', function () {
const root = res[res.length - 1]

expect(root.path).to.equal('test-site')
expect(root.cid).to.deep.equal(new CID(webpage.cid))
expect(root.cid.toString()).to.equal(webpage.cid)
})

after(() => factory.clean())
Expand Down Expand Up @@ -305,7 +304,7 @@ describe('resolve web page (CIDv1)', function () {
const root = res[res.length - 1]

expect(root.path).to.equal('test-site')
expect(root.cid).to.deep.equal(new CID(webpage.cid))
expect(root.cid.toString()).to.equal(webpage.cid)
})

after(() => factory.clean())
Expand Down Expand Up @@ -358,7 +357,7 @@ describe('mime-types', () => {
const root = res[res.length - 1]

expect(root.path).to.equal('test-mime-types')
expect(root.cid).to.deep.equal(new CID(webpage.cid))
expect(root.cid.toString()).to.equal(webpage.cid)
})

after(() => factory.clean())
Expand Down
48 changes: 19 additions & 29 deletions test/resolver.spec.js
Original file line number Diff line number Diff line change
Expand Up @@ -5,16 +5,14 @@ const { expect } = require('aegir/utils/chai')

const loadFixture = require('aegir/utils/fixtures')
const { createFactory } = require('ipfsd-ctl')
const CID = require('cids')
const mh = require('multihashes')
const all = require('it-all')

const ipfsResolver = require('../src/resolver')

const factory = createFactory({
test: true,
type: 'proc',
ipfsModule: require('ipfs')
ipfsModule: require('ipfs-core')
})

describe('resolve file (CIDv0)', function () {
Expand All @@ -33,7 +31,7 @@ describe('resolve file (CIDv0)', function () {
ipfs = ipfsd.api

const retrievedFile = await ipfs.add(file.data, { cidVersion: 0 })
expect(retrievedFile.cid).to.deep.equal(new CID(file.cid))
expect(retrievedFile.cid.toString()).to.equal(file.cid)
})

after(() => factory.clean())
Expand All @@ -42,20 +40,15 @@ describe('resolve file (CIDv0)', function () {
const res = await ipfsResolver.multihash(ipfs, `/ipfs/${file.cid}`)

expect(res).to.exist()
const expectedCid = new CID(file.cid)
expect(res).to.deep.include({
multihash: mh.toB58String(expectedCid.multihash)
})
expect(res).to.have.property('multihash', file.cid)
})

it('should resolve a cid', async () => {
const res = await ipfsResolver.cid(ipfs, `/ipfs/${file.cid}`)

expect(res).to.exist()
const expectedCid = new CID(file.cid)
expect(res).to.deep.include({
cid: expectedCid
})
expect(res).to.have.property('cid')
expect(res.cid.toString()).to.equal(file.cid)
})
})

Expand All @@ -75,7 +68,7 @@ describe('resolve file (CIDv1)', function () {
ipfs = ipfsd.api

const retrievedFile = await ipfs.add(file.data, { cidVersion: 1 })
expect(retrievedFile.cid).to.deep.equal(new CID(file.cid))
expect(retrievedFile.cid.toString()).to.equal(file.cid)
expect(retrievedFile.size, 'ipfs.files.add result size should not be smaller than input buffer').equal(file.data.length)
})

Expand All @@ -85,20 +78,15 @@ describe('resolve file (CIDv1)', function () {
const res = await ipfsResolver.multihash(ipfs, `/ipfs/${file.cid}`)

expect(res).to.exist()
const expectedCid = new CID(file.cid)
expect(res).to.deep.include({
multihash: mh.toB58String(expectedCid.multihash)
})
expect(res).to.have.property('multihash', file.cid)
})

it('should resolve a cid', async () => {
const res = await ipfsResolver.cid(ipfs, `/ipfs/${file.cid}`)

expect(res).to.exist()
const expectedCid = new CID(file.cid)
expect(res).to.deep.include({
cid: expectedCid
})
expect(res).to.have.property('cid')
expect(res.cid.toString()).to.equal(file.cid)
})
})

Expand Down Expand Up @@ -134,7 +122,7 @@ describe('resolve directory (CIDv0)', function () {
const root = res[res.length - 1]

expect(root.path).to.equal('test-folder')
expect(root.cid).to.deep.equal(new CID(directory.cid))
expect(root.cid.toString()).to.equal(directory.cid)
})

after(() => factory.clean())
Expand All @@ -149,8 +137,9 @@ describe('resolve directory (CIDv0)', function () {
}
})

it('should return HTML listing of files of a directory', async () => {
const res = await ipfsResolver.directory(ipfs, `/ipfs/${directory.cid}`, new CID(directory.cid))
// TODO: unskip when https://github.com/ipfs/js-ipfs/pull/3556 lands
it.skip('should return HTML listing of files of a directory', async () => {
const res = await ipfsResolver.directory(ipfs, `/ipfs/${directory.cid}`, directory.cid)

expect(res).to.exist()
expect(res).to.include('</html>')
Expand Down Expand Up @@ -191,7 +180,7 @@ describe('resolve directory (CIDv1)', function () {
expect(root.path).to.equal('test-folder')
// expect(res[0].size, 'ipfs.files.add 1st result size should not be smaller than 1st input buffer').greaterThan(dirs[0].content.length)
// expect(res[1].size, 'ipfs.files.add 2nd result size should not be smaller than 2nd input buffer').greaterThan(dirs[1].content.length)
expect(root.cid).to.deep.equal(new CID(directory.cid))
expect(root.cid.toString()).to.equal(directory.cid)
})

after(() => factory.clean())
Expand All @@ -206,8 +195,9 @@ describe('resolve directory (CIDv1)', function () {
}
})

it('should return HTML listing of files of a directory', async () => {
const res = await ipfsResolver.directory(ipfs, `/ipfs/${directory.cid}`, new CID(directory.cid))
// TODO: unskip when https://github.com/ipfs/js-ipfs/pull/3556 lands
it.skip('should return HTML listing of files of a directory', async () => {
const res = await ipfsResolver.directory(ipfs, `/ipfs/${directory.cid}`, directory.cid)
expect(res).to.exist()
expect(res).to.include('pp.txt')
expect(res).to.include('holmes.txt')
Expand Down Expand Up @@ -249,7 +239,7 @@ describe('resolve web page (CIDv0)', function () {
const root = res[res.length - 1]

expect(root.path).to.equal('test-site')
expect(root.cid).to.deep.equal(new CID(webpage.cid))
expect(root.cid.toString()).to.deep.equal(webpage.cid)
})

after(() => factory.clean())
Expand Down Expand Up @@ -308,7 +298,7 @@ describe('resolve web page (CIDv1)', function () {
// console.log(res)
const root = res[res.length - 1]
expect(root.path).to.equal('test-site')
expect(root.cid).to.deep.equal(new CID(webpage.cid))
expect(root.cid.toString()).to.equal(webpage.cid)
})

after(() => factory.clean())
Expand Down