Skip to content

A thorough specification and conformance suite for builtins.fetchTree and lock file items [maintainer=@roberth,@flokli,@lf-]

Notifications You must be signed in to change notification settings

nix-community/fetchTree-spec

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

2 Commits
 
 

Repository files navigation

fetchTree specification and conformance suite

builtins.fetchTree allows expressions in the Nix language to make use of files that reside in various places, such as other Git repositories.

The Nix expression language aims to be reproducible, so it follows that the behavior of fetchTree must be consistent between implementations, and consistent over time.

When this consistency is lost, you lose the ability to produce the same derivations, which in turns causes other problems such as an inability to use the existing contents of your binary cache for those derivations affected.

For these reasons it is crucial that we pin down the exact behavior of built-in fetchers, not just for a single Nix implementation, but in the wider Nix ecosystem.

Fixed-output derivations are a different method for fetching, which relies on a combination of a derivation build and output hash to achieve a similar result, but with different characteristics. Notably they require the execution of code that is provided by the expressions, whereas fetchTree does not. Refer to "import from derivation" for why that may not be desirable.

Work in progress

This repository aims to provide a specification and a conformance suite: files that can be used in implementations' test suites.

You are invited to collaborate.

About

A thorough specification and conformance suite for builtins.fetchTree and lock file items [maintainer=@roberth,@flokli,@lf-]

Topics

Resources

Code of conduct

Security policy

Stars

Watchers

Forks

Releases

No releases published

Sponsor this project