Closed samuelgja closed 4 weeks ago
Hi @samuelgja, thanks for the report. I think the root cause here is Bun's Buffer.utf8Slice
; you can reproduce the issue without avsc
:
Buffer.from('abc').utf8Slice(0, 1); // Throws TypeError: Expected string
I'm not familiar with Bun but it looks like the argument order here might not match the underlying implementation (which expects the encoding first, same as Node). Consider filing an issue there.
In the meantime, you may be able to work around this by patching the implementation:
Buffer.prototype.utf8Slice = function (start, end) {
return this.toString('utf8', start, end);
}
On latest master
(14886e84f6505248b0a6513b173df0a228738d66) you can now use bun
(tested with 1.1.29
) out of the box.
Try checking out the repo and then:
bun run mocha --ui tdd
You can try it via:
nix develop --command bun run mocha --ui tdd
with the following Nix flake:
{
description = "Bun workflow";
inputs = {
flake-parts.url = "github:hercules-ci/flake-parts";
nixpkgs.url = "github:NixOS/nixpkgs";
};
outputs = inputs@{ self, flake-parts, ... }:
flake-parts.lib.mkFlake { inherit inputs; } {
systems =
[ "x86_64-linux" "aarch64-linux" "x86_64-darwin" "aarch64-darwin" ];
perSystem = { config, self', inputs', pkgs, ... }: {
devShells.default = pkgs.mkShell {
buildInputs = with pkgs; [
bun
];
};
};
};
}
(see https://github.com/joscha/avsc/commit/0e568e32c6f8ea472cb48baa78daeb6b61d650ef)
Given all unit tests pass I'd think this issue can be closed. We could potentially define bun support in the package.json
and add a github workflow for it, if @mtth is happy to give it official support in the future.
Do tests also run for avsc
5.x
on current bun
? If so, closing SGTM. If not, let's close when 6.0
is released.
Adding official support will be best done separately if/when there is demand for it.
Yes 5.x (778f8daa057b39b9538ebaa04f7c382bd95482b2) passes well:
Great, thank you for confirming. Closing.
Motivation
Support for new bun runtime
What's wrong
I'am using avsc in node, but starting digging into new bun runtime and I tried to move some of my lib to bun, but avsc has error while using
fromBuffer
method. error is:Note this error is from
bun run test.js
script, not node.I tried to dig into the lib itself and try to find the issue, but it's too big for me :D without knowing context. So maybe it can be easy fix, maybe not. Maybe it's issue with bun and not with avsc.
If it's issue with bun itself, please close.
Code to reproduce
I found out it only happend on
string
type.