##// END OF EJS Templates
typing: make `bundlerepository` subclass `localrepository` while type checking...
typing: make `bundlerepository` subclass `localrepository` while type checking Currently, `mercurial/bundlerepo.py` is excluded from pytype, mostly because it complains that various `ui` and `vfs` fields in `localrepository` are missing. (`bundlerepository` dynamically subclasses `localrepository` when it is instantiated, so it works at runtime.) This makes that class hierarchy known to pytype. Having a protocol for `Repository` is probably the right thing to do, but that will be a lot of work and this still reflects the class at runtime. Subclassing also has the benefit of making sure any method overrides have a matching signature, so maybe this is a situation where we do both of these things. (I'm not sure how clear the diagnostics are if a class *almost* implements a protocol, but is missing a method argument or similar.) The subclassing is not done outside of type checking runs to avoid any side effects on already complex code.

File last commit:

r51872:4c5f6e95 default
r52763:9d4ad05b default
Show More
tests.rs
165 lines | 5.3 KiB | application/rls-services+xml | RustLexer
Simon Sapin
copies-rust: add a macro-based unit-testing framework...
r47414 use super::*;
Raphaël Gomès
rust: make `Revision` a newtype...
r51872 /// Shorthand to reduce boilerplate when creating [`Revision`] for testing
macro_rules! R {
($revision:literal) => {
Revision($revision)
};
}
Simon Sapin
copies-rust: add a macro-based unit-testing framework...
r47414 /// Unit tests for:
///
/// ```ignore
/// fn compare_value(
/// current_merge: Revision,
/// merge_case_for_dest: impl Fn() -> MergeCase,
/// src_minor: &CopySource,
/// src_major: &CopySource,
/// ) -> (MergePick, /* overwrite: */ bool)
/// ```
#[test]
fn test_compare_value() {
// The `compare_value!` macro calls the `compare_value` function with
// arguments given in pseudo-syntax:
//
// * For `merge_case_for_dest` it takes a plain `MergeCase` value instead
// of a closure.
// * `CopySource` values are represented as `(rev, path, overwritten)`
// tuples of type `(Revision, Option<PathToken>, OrdSet<Revision>)`.
// * `PathToken` is an integer not read by `compare_value`. It only checks
// for `Some(_)` indicating a file copy v.s. `None` for a file deletion.
// * `OrdSet<Revision>` is represented as a Python-like set literal.
use MergeCase::*;
use MergePick::*;
assert_eq!(
Raphaël Gomès
rust: make `Revision` a newtype...
r51872 compare_value!(
R!(1),
Normal,
(R!(1), None, { R!(1) }),
(R!(1), None, { R!(1) })
),
Simon Sapin
copies-rust: add a macro-based unit-testing framework...
r47414 (Any, false)
);
}
/// Unit tests for:
///
/// ```ignore
/// fn merge_copies_dict(
/// path_map: &TwoWayPathMap, // Not visible in test cases
/// current_merge: Revision,
/// minor: InternalPathCopies,
/// major: InternalPathCopies,
/// get_merge_case: impl Fn(&HgPath) -> MergeCase + Copy,
/// ) -> InternalPathCopies
/// ```
#[test]
fn test_merge_copies_dict() {
// The `merge_copies_dict!` macro calls the `merge_copies_dict` function
// with arguments given in pseudo-syntax:
//
// * `TwoWayPathMap` and path tokenization are implicitly taken care of.
// All paths are given as string literals.
// * Key-value maps are represented with `{key1 => value1, key2 => value2}`
// pseudo-syntax.
// * `InternalPathCopies` is a map of copy destination path keys to
// `CopySource` values.
// - `CopySource` is represented as a `(rev, source_path, overwritten)`
// tuple of type `(Revision, Option<Path>, OrdSet<Revision>)`.
// - Unlike in `test_compare_value`, source paths are string literals.
// - `OrdSet<Revision>` is again represented as a Python-like set
// literal.
// * `get_merge_case` is represented as a map of copy destination path to
// `MergeCase`. The default for paths not in the map is
// `MergeCase::Normal`.
//
// `internal_path_copies!` creates an `InternalPathCopies` value with the
// same pseudo-syntax as in `merge_copies_dict!`.
use MergeCase::*;
assert_eq!(
merge_copies_dict!(
Raphaël Gomès
rust: make `Revision` a newtype...
r51872 R!(1),
{"foo" => (R!(1), None, {})},
Simon Sapin
copies-rust: add a macro-based unit-testing framework...
r47414 {},
{"foo" => Merged}
),
Raphaël Gomès
rust: make `Revision` a newtype...
r51872 internal_path_copies!("foo" => (R!(1), None, {}))
Simon Sapin
copies-rust: add a macro-based unit-testing framework...
r47414 );
}
/// Unit tests for:
///
/// ```ignore
/// impl CombineChangesetCopies {
/// fn new(children_count: HashMap<Revision, usize>) -> Self
///
/// // Called repeatedly:
/// fn add_revision_inner<'a>(
/// &mut self,
/// rev: Revision,
/// p1: Revision,
/// p2: Revision,
/// copy_actions: impl Iterator<Item = Action<'a>>,
/// get_merge_case: impl Fn(&HgPath) -> MergeCase + Copy,
/// )
///
/// fn finish(mut self, target_rev: Revision) -> PathCopies
/// }
/// ```
#[test]
fn test_combine_changeset_copies() {
// `combine_changeset_copies!` creates a `CombineChangesetCopies` with
// `new`, then calls `add_revision_inner` repeatedly, then calls `finish`
// for its return value.
//
// All paths given as string literals.
//
// * Key-value maps are represented with `{key1 => value1, key2 => value2}`
// pseudo-syntax.
// * `children_count` is a map of revision numbers to count of children in
// the DAG. It includes all revisions that should be considered by the
// algorithm.
// * Calls to `add_revision_inner` are represented as an array of anonymous
// structs with named fields, one pseudo-struct per call.
//
// `path_copies!` creates a `PathCopies` value, a map of copy destination
// keys to copy source values. Note: the arrows for map literal syntax
// point **backwards** compared to the logical direction of copy!
Raphaël Gomès
rust-clippy: merge "revlog" module definition and struct implementation...
r50832 use crate::revlog::NULL_REVISION as NULL;
Simon Sapin
copies-rust: add a macro-based unit-testing framework...
r47414 use Action::*;
use MergeCase::*;
assert_eq!(
combine_changeset_copies!(
Raphaël Gomès
rust: make `Revision` a newtype...
r51872 { R!(1) => 1, R!(2) => 1 },
Simon Sapin
copies-rust: add a macro-based unit-testing framework...
r47414 [
Raphaël Gomès
rust: make `Revision` a newtype...
r51872 {
rev: R!(1),
p1: NULL,
p2: NULL,
actions: [],
merge_cases: {},
},
Simon Sapin
copies-rust: add a macro-based unit-testing framework...
r47414 {
Raphaël Gomès
rust: make `Revision` a newtype...
r51872 rev: R!(2),
p1: NULL,
p2: NULL,
actions: [],
merge_cases: {},
},
{
rev: R!(3), p1: R!(1), p2: R!(2),
Simon Sapin
copies-rust: add a macro-based unit-testing framework...
r47414 actions: [CopiedFromP1("destination.txt", "source.txt")],
merge_cases: {"destination.txt" => Merged},
},
],
Raphaël Gomès
rust: make `Revision` a newtype...
r51872 R!(3),
Simon Sapin
copies-rust: add a macro-based unit-testing framework...
r47414 ),
path_copies!("destination.txt" => "source.txt")
);
}