incr.comp.: Create Test Case for Incr. Comp. Hash for const declarations #37000
Labels
A-incr-comp
Area: Incremental compilation
E-easy
Call for participation: Easy difficulty. Experience needed to fix: Not much. Good first issue.
E-mentor
Call for participation: This issue has a mentor. Use #t-compiler/help on Zulip for discussion.
This issue is part of a broader effort to implement comprehensive regression testing for incremental compilation. For the tracking issue go to #36350.
Background
For incremental compilation we need to determine if a given HIR node has changed in between two versions of a program. This is implemented in the calculate_svh module. We compute a hash value for each HIR node that corresponds to a node in the dependency graph and then compare those hash values. We call this hash value the Incremental Compilation Hash (ICH) of the HIR node. It is supposed to be sensitive to any change that might make a semantic difference to the thing being hashed.
Testing Methodology
The auto-tests in the
src/test/incremental
directory all follow the same pattern:--cfg
flag, allowing each version to differ via conditional compilation. Each of these versions we call a revision.#[rustc_clean]
/#[rustc_dirty]
).The ICH-specific tests use this framework by adhering to the following pattern:
#[cfg(cfail1)]
and the second marked with#[cfg(not(cfail1))]
. As a consequence, the first revision will be compiled with the first version of the definition, and all other revisions will be compiled with the second version. The two versions are supposed to differ in exactly one aspect (e.g. the visibility of a field is different, or the return of a function has changed).#[rustc_dirty(label="Hir", cfg="cfail2")]
attribute attached. This attribute makes the test runner check that a change of theHir
dependency node of the definition has been detected between revisionscfail1
andcfail2
. This will effectively test that a different ICH value has been computed for the two versions of the definition.#[rustc_clean(label="Hir", cfg="cfail3")]
attribute. This makes sure that theHir
dependency node (and thus the ICH) of the definition has not changed between revisionscfail2
andcfail3
. That's what we expect, because both revisions use the same version of the definition.#[rustc_metadata_clean]
/#[rustc_metadata_dirty]
attributes and works analogous to theHir
case: We add#[rustc_metadata_dirty(cfg="cfail2")]
to the second definition to make sure that the ICH of the exported metadata is not the same for the different versions of the definition, and we add#[rustc_metadata_dirty(cfg="cfail3")]
to make sure that the ICH is the same for the two identical versions of the definition.Why are the revisions called "cfail"? That's because of reasons internal to how
the test-runner works. Prefixing a revision with "cfail" tells the test runner to treat the test like a "compile-file" test, that is: compile the test case but don't actually run it (which would be the case for an "rpass" revision). For the ICH tests we need to compile "rlibs", so that we can test metadata ICHs. As a consequence we cannot declare them "rpass". In an additional directive (
// must-compile-successfully
), we tell the test runner that we actually expect the file to not produce any errors.Each test case must contain the following test-runner directives and crate attributes at the top:
See src/test/incremental/hashes/struct_defs.rs for a full example of such a ICH regression test.
Const Declaration Specific ICH Testing
Each of the following things should be tested with its own definition pair:
const
const
fromi32
tou32
const
fromOption<u32>
toOption<u64>
const
from a simple literal to another one (e.g.1
to2
)const
from1 + 1
to1 + 2
const
from2 + 3
to2 * 3
const
from1 + 2 * 3
=>1 + 2 * 4
const
indirectly by modifying a use statementThe text was updated successfully, but these errors were encountered: