Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: Re-enable interface tests and get them succeeding #83

Merged
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
90 commits
Select commit Hold shift + click to select a range
3bf928e
chore: sync with ipfs/test/interface-http-go.js
SgtPooki Nov 3, 2022
07fed40
chore: install multiple go-ipfs versions
SgtPooki Nov 3, 2022
58243e5
fix: .bitswap.wantlist before test
SgtPooki Nov 10, 2022
8ce3abb
fix: .bitswap.wantlistForPeer before
SgtPooki Nov 10, 2022
27db517
chore: enable running interface tests against multiple kubo versions
SgtPooki Nov 10, 2022
2a282dc
fix: bitswap ipfs spawn types
SgtPooki Nov 10, 2022
0c84c21
fix: dht utils ipfs api usage
SgtPooki Nov 10, 2022
5b9c92d
fix: dag.get test
SgtPooki Nov 10, 2022
c8b95e7
fix: dht tests
SgtPooki Nov 10, 2022
aa3948d
fix: .id test
SgtPooki Nov 10, 2022
f8598e1
fix: pinning service tests
SgtPooki Nov 10, 2022
b9e5325
fix: misc tests
SgtPooki Nov 10, 2022
0c182ff
fix: pinning tests
SgtPooki Nov 10, 2022
aa1c7e6
fix: .ping tests
SgtPooki Nov 10, 2022
63916fe
fix: .swarm.peers passes
SgtPooki Nov 22, 2022
b6f7c01
fix: .swarm.addrs passes
SgtPooki Nov 23, 2022
e22f89c
fix: .swarm.disconnect passes
SgtPooki Nov 23, 2022
bd67b63
fix: all tests are passing in node
SgtPooki Nov 23, 2022
011268f
fix: browser interface tests are passing or skipped
SgtPooki Nov 23, 2022
298f534
fix: webworker tests pass
SgtPooki Nov 23, 2022
e370e56
feat: fix webworker tests
SgtPooki Nov 29, 2022
c002718
chore: code cleanup
SgtPooki Nov 29, 2022
8ab1d39
chore: commentary and code cleanup
SgtPooki Nov 29, 2022
c57ecc4
fix: update package-lock.json
hacdias Dec 5, 2022
47b0a5a
chore: update current go-ipfs to v0.17
hacdias Dec 5, 2022
1efca00
chore: 'should compress a directory as a tarball' actually passes
hacdias Dec 5, 2022
8765872
Revert "chore: 'should compress a directory as a tarball' actually pa…
hacdias Dec 5, 2022
731b9e9
use lts on test node
hacdias Dec 5, 2022
16cc34f
fix: .pubsub.subscribe tests
SgtPooki Dec 7, 2022
e0d0f7e
chore: actually wait for factory cleanup
SgtPooki Dec 7, 2022
f29d6b8
chore: fix lint and package-lock
SgtPooki Dec 7, 2022
e0f4fb1
fix: dep-check
SgtPooki Dec 7, 2022
720791a
chore: skip .refs tests
SgtPooki Dec 7, 2022
a3daf1f
chore: remove root tests not implemented in kubo
SgtPooki Dec 7, 2022
2723b6e
chore: add lint:fix script
SgtPooki Dec 7, 2022
6185634
chore: consolidate eslint configs and add mocha plugin
SgtPooki Dec 7, 2022
e0a2eea
chore: fix mocha lint failures
SgtPooki Dec 7, 2022
3a76268
chore: remove check for cidv0 from block.put
SgtPooki Dec 7, 2022
8623205
chore: attempt to fix hang after test
SgtPooki Dec 7, 2022
33d1c6b
chore: skip broken test
SgtPooki Dec 8, 2022
7379ba0
fix: ipfs libs do not work with node LTS fetch
SgtPooki Dec 8, 2022
31e5ad6
fix: .cat beforeAll hook
SgtPooki Dec 8, 2022
60e38a2
fix: .get beforeAll
SgtPooki Dec 8, 2022
c8819db
chore: update logger name
SgtPooki Dec 8, 2022
e70563a
fix: .get test 'should get a directory'
SgtPooki Dec 8, 2022
d8efa60
chore: add dev helper scripts
SgtPooki Dec 8, 2022
01f8282
fix(test): should put a buffer, using defaults
SgtPooki Dec 8, 2022
1e98feb
chore: remove currently broken typedocs
SgtPooki Dec 8, 2022
36c5f60
fix(test): should error when removing non-existent blocks
SgtPooki Dec 8, 2022
3c47b9b
fix(test): should import car with roots but no blocks
SgtPooki Dec 8, 2022
4cbe1d0
chore: add more debug output to test
SgtPooki Dec 8, 2022
936156f
fix(test): should respect timeout option when removing a block
SgtPooki Dec 8, 2022
8c08e5d
chore(lint): fix lint failure
SgtPooki Dec 8, 2022
8e8538e
fix(test): should import car with roots but no blocks
SgtPooki Dec 9, 2022
9b7f879
fix(tests): .dag tests
SgtPooki Dec 9, 2022
4fc3866
fix(test): should fail to find other peer if peer does not exist
SgtPooki Dec 9, 2022
268f69d
chore(test): disable opsPerSec expectation
SgtPooki Dec 9, 2022
fb4a1b4
test(chore): supports concurrent writes
SgtPooki Dec 9, 2022
064dbeb
fix(tests): .pin.remote.ls
SgtPooki Dec 10, 2022
5169bb4
chore(lint): fix jsdoc complaint
SgtPooki Dec 10, 2022
5c11c55
chore(test): increase .pin.remote.rm & .rmAll timeouts
SgtPooki Dec 10, 2022
f18ecbb
fix(test): should receive multiple messages
SgtPooki Dec 10, 2022
16b6925
fix(test): should receive messages from a different node on lots of t…
SgtPooki Dec 10, 2022
e0ee6e2
fix(test): should unsubscribe individual handlers
SgtPooki Dec 10, 2022
7fe16b7
fix(test): .pubsub.peers
SgtPooki Dec 10, 2022
089f71d
chore: attempt to fix 'should list "queued" pins'
SgtPooki Dec 10, 2022
80b1a9c
fix(lint): unused import
SgtPooki Dec 10, 2022
cc0941f
chore: attempt to clear pins prior to .pin.remote.ls 'after adding pi…
SgtPooki Dec 10, 2022
0b5c93e
chore(tmp): don't fail fast in CI to ease debugging
SgtPooki Dec 10, 2022
37be08a
fix(test): .pubsub.subscribe
SgtPooki Dec 12, 2022
8f5883e
fix(lint): build passes
SgtPooki Dec 12, 2022
e2e89cf
fix(test): .pin.remote.ls
SgtPooki Dec 13, 2022
bcf3c79
chore: cleanup .aegir and add more types
SgtPooki Dec 13, 2022
2a8ce3a
chore: reduce duplication in js-test-and-release workflow
SgtPooki Dec 13, 2022
652d3c8
chore(tmp): temporarily bail=false and fail-fast=false for non-node t…
SgtPooki Dec 13, 2022
d1214c6
chore: remove tests for things not implemented in kubo
SgtPooki Dec 13, 2022
a9b2b71
feat: unskip should resolve IPNS link tests
SgtPooki Dec 13, 2022
cb2566a
fix(test): .get directories
SgtPooki Dec 13, 2022
0be613a
chore(test): skip should default to blocking pin on chrome
SgtPooki Dec 13, 2022
42773b5
fix(lint): build succeeds
SgtPooki Dec 13, 2022
65d42f1
chore(test): unskip should pin dag-cbor
SgtPooki Dec 13, 2022
b3da286
chore(test): increase 'with sharding' test timeout
SgtPooki Dec 13, 2022
6fa916a
chore: remove old go-ipfs version testing support
SgtPooki Dec 13, 2022
7a11168
fix(test): node/request-api - trailer headers
SgtPooki Dec 15, 2022
e2f3aa0
fix: test running when not in node
SgtPooki Dec 15, 2022
26c1504
chore: move byCID function to utils
SgtPooki Dec 15, 2022
059ce51
fix(test): 'should import car with roots but no blocks' succeeds cons…
SgtPooki Dec 15, 2022
6c27e9d
fix(test): re-add 'should export a chunk of a file'
SgtPooki Dec 15, 2022
f39eb81
fix(test): test 'should list peers this node is connected to' specifics
SgtPooki Dec 15, 2022
70058a2
chore: address the rest of the PR comments
SgtPooki Dec 15, 2022
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
19 changes: 17 additions & 2 deletions .aegir.js
Original file line number Diff line number Diff line change
@@ -1,19 +1,29 @@
import { createServer } from 'ipfsd-ctl'
import getPort from 'aegir/get-port'
import EchoServer from 'aegir/echo-server'

/**
* @typedef {object} BeforeType
* @property {import('ipfsd-ctl').Controller} server
* @property {EchoServer} echoServer
* @property {typeof import('./test/utils/mock-pinning-service.js')} pinningService
* @property {Record<string, string>} env
*/
/** @type {import('aegir').PartialOptions} */
export default {
build: {
bundlesizeMax: '66KB'
},
test: {
bail: false,
/**
*
* @param {Parameters<import('aegir').Options['test']['before']>[0]} options
* @returns {Promise<BeforeType>}
*/
async before (options) {
const { PinningService } = await import('./test/utils/mock-pinning-service.js')
const pinningService = await PinningService.start()
const server = createServer({
host: '127.0.0.1',
port: 0
}, {
type: 'go',
Expand All @@ -25,13 +35,18 @@ export default {
await echoServer.start()

await server.start()
/**
* @type {BeforeType}
*/
return {
server,
echoServer,
pinningService,
env: {
NODE_OPTIONS: '--no-experimental-fetch',
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Q: when we run Node with this, does it impact the runtime of tests, or is it run in a separate process?

(if it is the same process, it is a problem: we should be running tests with default Node LTS and no special parameters)

Copy link
Member Author

@SgtPooki SgtPooki Dec 15, 2022

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I'm not sure I fully understand your question, but I'll give some context around this:

  1. nodeJS 18 (not being tested currently for node tests in ipfs-http-client, so scope creep for this task) adopted native fetch, see https://nodejs.org/en/blog/announcements/v18-release-announce/#fetch-experimental.
    • This was previously under an opt-in flag --experimental-fetch, but in 18 was switched to opt-out with --no-experimental-fetch. Basically, any discrepancies between node-fetch and undici's fetch will need to be handled if we don't override global fetch in node with node-fetch.
    • I have a hunch that some of these discrepancies were one of the problems I had with unblocking the test/node/agent.js test.
  2. When we run tests, the flow is:

I think item 2 above tells us the answer to your question is that this is a separate process.

IPFSD_SERVER: `http://${server.host}:${server.server.info.port}`,
PINNING_SERVICE_ENDPOINT: pinningService.endpoint,
PINNING_SERVICE_KEY: 'secret',
ECHO_SERVER: `http://${echoServer.host}:${echoServer.port}`,
}
}
Expand Down
23 changes: 21 additions & 2 deletions .eslintrc.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,12 @@

{
"plugins": [
"jsdoc",
"mocha"
],
"extends": [
"plugin:jsdoc/recommended",
"plugin:mocha/recommended",
"ipfs"
],
"env": {
Expand All @@ -14,7 +20,20 @@
"rules": {
"no-return-await": "off",
"no-undef-init": "off",
"no-warning-comments": "off"
"no-warning-comments": "off",
"mocha/max-top-level-suites": "off",
"mocha/no-setup-in-describe": "off"
},
"ignorePatterns": [ "gists/", "vendor/", "test/fixtures/", "test/interface-tests/fixtures/"]
"ignorePatterns": [ "gists/", "vendor/", "test/fixtures/", "test/interface-tests/fixtures/"],
"overrides": [
{
"files": ["./test/interface-tests/src/**"],
"rules": {
"mocha/no-exports": "off",
"mocha/max-top-level-suites": "off",
"mocha/no-sibling-hooks": "warn",
"mocha/no-setup-in-describe": "off"
}
}
]
}
59 changes: 10 additions & 49 deletions .github/workflows/js-test-and-release.yml
Original file line number Diff line number Diff line change
Expand Up @@ -27,74 +27,35 @@ jobs:
strategy:
matrix:
os: [windows-latest, ubuntu-latest, macos-latest]
node: [16]
fail-fast: true
fail-fast: false
steps:
- uses: actions/checkout@v3
- uses: actions/setup-node@v3
with:
node-version: ${{ matrix.node }}
node-version: lts/*
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

⚠️

This project is managed via github.com/protocol/.github (config).

Does this mean the changes to this file from this PR will be overwritten by https://github.com/protocol/.github/blob/master/templates/.github/workflows/js-test-and-release.yml the next time CI sync runs?

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@galargh can you confirm?

Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Yes, it's going to get overwritten. Whenever https://github.com/protocol/.github/actions/workflows/dispatch.yml runs, it updates uCI files in all the repositories where it's configured (if needed of course). That's why files managed by uCI have this header:

# File managed by web3-bot. DO NOT EDIT.
# See https://github.com/protocol/.github/ for details.

Here's an automated PR that wants to update the workflow here: #85 (it would have been automerged if only test-node on windows passed).

If there's a change we want to introduce that would benefit all JS repos participating in uCI, then this would be the place to do it: https://github.com/protocol/.github/blob/master/templates/.github/workflows/js-test-and-release.yml

Side note: the way Unified CI provisions files is different from how GitHub Management does it. For example, if we were to modify https://github.com/ipfs/js-kubo-rpc-client/blob/master/.github/workflows/stale.yml which is managed here https://github.com/ipfs/github-mgmt/blob/eed32757b57354659c07d738d36ecfbc25a033ef/github/ipfs.yml#L4589-L4591, then the next sync would have noticed that the two diverged and would update the content in the YAML config.

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

So if a project needs to disable node LTS or other node versions for some reason, what is the best way to accomplish that?

Can we make the unified CI workflow dynamic with a default to LTS? I'm not sure the best way to accomplish this but it would allow individual projects to update/override when necessary. Without being overwritten.

- uses: ipfs/aegir/actions/cache-node-modules@master
- run: npm run --if-present test:node
- uses: codecov/codecov-action@81cd2dc8148241f03f5839d295e000b8f761e378 # v3.1.0
with:
flags: node

test-chrome:
needs: check
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- uses: actions/setup-node@v3
with:
node-version: lts/*
- uses: ipfs/aegir/actions/cache-node-modules@master
- run: npm run --if-present test:chrome
- uses: codecov/codecov-action@81cd2dc8148241f03f5839d295e000b8f761e378 # v3.1.0
with:
flags: chrome

test-chrome-webworker:
needs: check
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- uses: actions/setup-node@v3
with:
node-version: lts/*
- uses: ipfs/aegir/actions/cache-node-modules@master
- run: npm run --if-present test:chrome-webworker
- uses: codecov/codecov-action@81cd2dc8148241f03f5839d295e000b8f761e378 # v3.1.0
with:
flags: chrome-webworker

test-firefox:
needs: check
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- uses: actions/setup-node@v3
with:
node-version: lts/*
- uses: ipfs/aegir/actions/cache-node-modules@master
- run: npm run --if-present test:firefox
- uses: codecov/codecov-action@81cd2dc8148241f03f5839d295e000b8f761e378 # v3.1.0
with:
flags: firefox

test-firefox-webworker:
test-non-node-target:
needs: check
runs-on: ubuntu-latest
strategy:
matrix:
target: [chrome, chrome-webworker, firefox, firefox-webworker]
fail-fast: false
steps:
- uses: actions/checkout@v3
- uses: actions/setup-node@v3
with:
node-version: lts/*
- uses: ipfs/aegir/actions/cache-node-modules@master
- run: npm run --if-present test:firefox-webworker
- run: npm run --if-present test:${{ matrix.target }} -- --bail=false
- uses: codecov/codecov-action@81cd2dc8148241f03f5839d295e000b8f761e378 # v3.1.0
with:
flags: firefox-webworker
flags: ${{ matrix.target }}

test-electron-main:
needs: check
Expand Down Expand Up @@ -125,7 +86,7 @@ jobs:
flags: electron-renderer

release:
needs: [test-node, test-chrome, test-chrome-webworker, test-firefox, test-firefox-webworker, test-electron-main, test-electron-renderer]
needs: [test-node, test-non-node-target, test-electron-main, test-electron-renderer]
runs-on: ubuntu-latest
if: github.event_name == 'push' && github.ref == 'refs/heads/master' # with #262 - 'refs/heads/${{{ github.default_branch }}}'
steps:
Expand Down
69 changes: 55 additions & 14 deletions package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

24 changes: 9 additions & 15 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -54,18 +54,6 @@
"require": "./dist/src/index.js"
}
},
"eslintConfig": {
"extends": [
"ipfs",
"plugin:jsdoc/recommended"
],
"parserOptions": {
"sourceType": "module"
},
"plugins": [
"jsdoc"
]
},
"release": {
"branches": [
"master"
Expand Down Expand Up @@ -155,12 +143,15 @@
"build": "aegir build",
"test": "aegir test",
"docs": "typedoc src/index.js",
"test:node": "aegir test -t node --cov",
"test:node": "aegir test -t node --cov --bail=false",
"test:chrome": "aegir test -t browser --cov",
"test:chrome-webworker": "aegir test -t webworker",
"test:firefox": "aegir test -t browser -- --browser firefox",
"test:firefox-webworker": "aegir test -t webworker -- --browser firefox",
"lint": "aegir lint",
"lint:fix": "aegir lint --fix",
"check:push": "npm run dep-check && npm run lint && npm run build",
"check:push:deep": "npm run check:push && npm run test",
"clean": "aegir clean",
"dep-check": "aegir dep-check",
"release": "aegir release"
Expand Down Expand Up @@ -188,6 +179,7 @@
},
"devDependencies": {
"@ipld/car": "^5.0.0",
"@libp2p/interface-peer-id": "^1.0.6",
"@libp2p/interface-peer-info": "^1.0.2",
"@libp2p/interface-pubsub": "^3.0.0",
"@libp2p/interfaces": "^3.0.3",
Expand All @@ -197,11 +189,12 @@
"did-jwt": "^6.8.0",
"eslint-config-ipfs": "^3.1.0",
"eslint-plugin-jsdoc": "^39.3.6",
"go-ipfs": "^0.16.0",
"eslint-plugin-mocha": "^10.1.0",
"go-ipfs": "^0.17.0",
"ipfs-core-types": "^0.13.0",
"ipfs-unixfs": "^8.0.0",
"ipfs-unixfs-importer": "^11.0.1",
"ipfsd-ctl": "^12.2.1",
"ipfsd-ctl": "^12.2.2",
"ipns": "^4.0.0",
"is-ipfs": "^7.0.2",
"iso-random-stream": "^2.0.2",
Expand All @@ -222,6 +215,7 @@
"p-defer": "^4.0.0",
"p-map": "^5.5.0",
"p-retry": "^5.1.1",
"p-timeout": "^4.1.0",
"pako": "^2.0.4",
"peer-id": "^0.16.0",
"readable-stream": "^4.2.0",
Expand Down
Loading