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

Using hurl as a library #284

Closed
nikeee opened this issue Oct 10, 2021 · 12 comments
Closed

Using hurl as a library #284

nikeee opened this issue Oct 10, 2021 · 12 comments

Comments

@nikeee
Copy link
Contributor

nikeee commented Oct 10, 2021

I really love this tool. I loce it so much that I'd like to integrate it into some project. If I'm not mistaking, it's currently only a CLI tool (and a rust crate).

Sadly, most of my current projects that would benefit from this aren't written in rust. Would it be possible to somehow provide a version of this with FFI wrappers to the main part? Glancing at the source, this seems to be the function that would need to be wrapped:

fn execute(
filename: &str,
contents: String,
current_dir: &Path,
cli_options: CliOptions,
log_verbose: &impl Fn(&str),
log_error_message: &impl Fn(bool, &str),
progress: Option<Progress>,
) -> HurlResult {

Also, are there non-statically linked parts?

@fabricereix
Copy link
Collaborator

Hello,
As crate, Hurl can be used "technically" as a library. But the APIs still needs to be improved.
Relating to non-statically linked parts, Hurl relies on libcurl and libxml.

@fabricereix
Copy link
Collaborator

From what language you would like to call the Hurl API? Python?
If you can manage something, we will be interested by your feedback.

@nikeee
Copy link
Contributor Author

nikeee commented Oct 10, 2021

It's currently .NET, which can consume exported C functions. I'm not that much into rust, but I assume that this would require some bindgen stuff.
In the application, I want to offer the user a way of defining HTTP request with any complexity. It seems like Hurl would fit the job pretty good, since requests can be chained and variables can be injected + captured.

Python would be interesting, too.

@tbolon
Copy link

tbolon commented Oct 12, 2021

FYI, in my case I am planning to write a .NET wrapper around the hurl process, which launch the hurl process then parse output.

But in my case I will run a lot of hurl files (think integration tests), so it makes sense to not reuse hurl and run multiple process in parallel. This way I also avoid any resource leak between the host and the multiple runs.

@nikeee
Copy link
Contributor Author

nikeee commented Oct 13, 2021

I think the first step could be to just provide a create that exposes the above mentioned execute function.
From that on, we can create a create (possibly independent) that wraps this function + types to whatever someone needs.

@fabricereix
Copy link
Collaborator

We will try to create an example using Hurl as a lib.

@humphd
Copy link

humphd commented Apr 15, 2022

This is something that would be cool to do with node.js and something like https://neon-bindings.com/. I'd love to see Hurl become more accessible to JS devs, many of whom aren't used to adding tools from outside the npm-ecosystem.

@fabricereix
Copy link
Collaborator

Yes, It would be good to see Hurl in the Browser/JS space.
It would useful for example to create a Hurl playground.

I initially thought about generating standard Web Assembly from Hurl Rust source code.
But HTTP requests have to be handled outside Web Assembly.

I don't know about https://neon-bindings.com.
It can be interesting to see how it handles these HTTP calls.

@jcamiel
Copy link
Collaborator

jcamiel commented Apr 26, 2022

@humphd @fabricereix thinking about this issue, I'm wondering if publishing Hurl binaries to npm registry will not be sufficient (instead of building through Neon or WASM). For instance, dprint is a code formatter written in Rust and you can install it with cargo, brew, npm etc...:

$ brew install dprint
$ cargo install dprint
$ npm install dprint

On npm package, dprint is listed as "npm CLI distribution for dprint"

If we do the same with the existing Hurl binaries (publishing to npm), it should be sufficient to reach JS devs ?

@humphd
Copy link

humphd commented Apr 26, 2022

This would be great, yes. Being able to install and run hurl via npm (e.g., having it get put in node_modules/.bin and being able to use it via npm scripts, like "test": "hurl --test ...") would accomplish what I'm after.

Looking at https://github.com/dprint/dprint/tree/main/deployment/npm seems to provide a good path forward. I tried installing it, and it does exactly what hurl should do: a binary is downloaded and npm can call it:

$ tree -a node_modules
node_modules
├── .bin
│   └── dprint -> ../dprint/bin.js
├── .package-lock.json
└── dprint
    ├── LICENSE
    ├── README.md
    ├── bin.js
    ├── dprint
    ├── info.json
    ├── install.js
    ├── install.ps1
    ├── install.sh
    ├── install_verify_checksum.js
    └── package.json

@humphd
Copy link

humphd commented Apr 26, 2022

I filed #544 to deal with the npm install case, so I don't hijack this issue.

@jcamiel
Copy link
Collaborator

jcamiel commented Dec 9, 2022

We've added a sample using Hurl as a library here /contrib/sample. We're using it now in the CI (see #972 ) to detect major changes in Hurl's crates API and can be used as a base for samples. I'm closing this issue for the moment.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

5 participants