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

@edgedb/generate scripts not executing properly with bun version 1.1.10 #11453

Open
mcisne4 opened this issue May 29, 2024 · 3 comments
Open
Labels
bug Something isn't working

Comments

@mcisne4
Copy link

mcisne4 commented May 29, 2024

What version of Bun is running?

1.1.9+bb13798d9

What platform is your computer?

Linux 6.5.0-35-generic x86_64 x86_64

What steps can reproduce the bug?

The latest version of bun (v1.1.10) has potential incompatibilities with EdgeDB's TypeScript/JavaScript generators. #1032

When using the latest version of bun (v1.1.10), the bunx @edgedb/generate queries and the bunx @edgedb/generate interfaces scripts do not fully execute. Execution of the scripts starts properly but suddenly terminates after attempting to connect to the database. No errors are emitted, execution just stops. No files are generated as a result.

The above issue is resolved if I roll back to the previous version of bun (v1.1.9).

Quick Project Setup:

# Initialize Bun Project
mkdir edgedb-project && cd edgedb-project
bun init

# Add EdgeDB Dependencies:
bun add edgedb
bun add -D @edgedb/generate

# Initialize EdgeDB:
edgedb project init

# Add Schema Information
cat > dbschema/default.esdl << EOF
module default {
  type Person {
    name: str;
  }
}
EOF

# Schema Migration:
edgedb migration create
edgedb migrate

# Add EdgeBD Query:
mkdir queries
cat > queries/insertPerson.edgeql << EOF
insert Person {
  name := <str>\$name
}
EOF

Bug:
Executing the queries or interfaces command should generate database related TypeScript files.

# Queries Generator:
bunx @edgedb/generate queries

# Interfaces Generator:
bunx @edgedb/generate interfaces

When using bun version 1.1.10, execution does not complete and no files are generated. When using version 1.1.9 or older, the files are generated successfully.

What is the expected behavior?

Executing the queries generation script:

# [Bun v1.1.9]
# Proper Execution:
> bunx @edgedb/generate queries
Generating functions from .edgeql files...
Detected tsconfig.json, generating TypeScript files.
   To override this, use the --target flag.
   Run `npx @edgedb/generate --help` for full options.
Detected project root via edgedb.toml:
   /home/mcisne4/dev/bun/experiment-26
Detected schema directory: dbschema
Connecting to database...
Analyzing .edgeql files...
Generating files for following queries:
   ./queries/insertXYZ.query.ts

Executing the interfaces generation script:

# [Bun v1.1.9]
# Proper Execution:
> bunx @edgedb/generate interfaces
Generating TS interfaces from schema...
Introspecting database schema...
Generating interfaces...
Writing interfaces file...
   ./dbschema/interfaces.ts
Generation complete! 🤘

What do you see instead?

Executing the queries generation script

# [Bun v1.1.10]
# Improper Execution:
> bunx @edgedb/generate queries
Generating functions from .edgeql files...
Detected tsconfig.json, generating TypeScript files.
   To override this, use the --target flag.
   Run `npx @edgedb/generate --help` for full options.
Detected project root via edgedb.toml:
   /home/mcisne4/dev/bun/experiment-26
Detected schema directory: dbschema
Connecting to database...

Executing the interfaces generation script:

# [Bun v1.1.10]
# Improper Execution:
> bunx @edgedb/generate interfaces
Generating TS interfaces from schema...
Introspecting database schema...

Additional information

No response

@mcisne4 mcisne4 added the bug Something isn't working label May 29, 2024
@mcisne4 mcisne4 changed the title @edgedb/generate scripts not executing properly with bun version 1.1.0 @edgedb/generate scripts not executing properly with bun version 1.1.10 May 30, 2024
@corbinu
Copy link

corbinu commented Jun 27, 2024

@mcisne4 I am not seeing this issue when using the latest bun and edgedb. Can you try again?

Thanks!

@mcisne4
Copy link
Author

mcisne4 commented Jun 28, 2024

@corbinu I have been getting things to work by installing Node alongside Bun. Previously I was only running on Bun.

To check that it wasn't my system, I tried it again on a fresh install of Ubuntu 23.10 (in preview mode). I installed Bun and EdgeDB and tried the above steps again.

Bun v1.1.9 | No Node - Everything works as expected

Bun v1.1.10 | No Node - ...forgot to test

Bun v1.1.17 | No Node - The generation commands do not execute completely. No errors are thrown.

Bun v1.1.17 | Node v22.3.0 - Everything works as expected

The bug seems to persist with the latest version of Bun if Node is not present. However, everything works as expected when rolling back to Bun v1.1.9, without the need to also have Node installed.

NOTE: I have not tried the above steps in the latest Ubuntu version, which would be a better target

@corbinu
Copy link

corbinu commented Jul 1, 2024

@mcisne4 I installed bun in a brand new lubuntu vm with no node and can confirm this is still an issue. Thanks!

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something isn't working
Projects
None yet
Development

No branches or pull requests

2 participants