tests/test-contrib-relnotes.t
author Gregory Szorc <gregory.szorc@gmail.com>
Thu, 06 Sep 2018 14:04:46 -0700
changeset 39568 842cd0bdda75
parent 39434 4971c9724206
child 40452 683e99f0b30c
permissions -rw-r--r--
util: teach lrucachedict to enforce a max total cost Now that lrucachedict entries can have a numeric cost associated with them and we can easily pop the oldest item in the cache, it now becomes relatively trivial to implement support for enforcing a high water mark on the total cost of items in the cache. This commit teaches lrucachedict instances to have a max cost associated with them. When items are inserted, we pop old items until enough "cost" frees up to make room for the new item. This feature is close to zero cost when not used (modulo the insertion regressed introduced by the previous commit): $ ./hg perflrucachedict --size 4 --gets 1000000 --sets 1000000 --mixed 1000000 ! gets ! wall 0.607444 comb 0.610000 user 0.610000 sys 0.000000 (best of 17) ! wall 0.601653 comb 0.600000 user 0.600000 sys 0.000000 (best of 17) ! inserts ! wall 0.678261 comb 0.680000 user 0.680000 sys 0.000000 (best of 14) ! wall 0.685042 comb 0.680000 user 0.680000 sys 0.000000 (best of 15) ! sets ! wall 0.808770 comb 0.800000 user 0.800000 sys 0.000000 (best of 13) ! wall 0.834241 comb 0.830000 user 0.830000 sys 0.000000 (best of 12) ! mixed ! wall 0.782441 comb 0.780000 user 0.780000 sys 0.000000 (best of 13) ! wall 0.803804 comb 0.800000 user 0.800000 sys 0.000000 (best of 13) $ hg perflrucachedict --size 1000 --gets 1000000 --sets 1000000 --mixed 1000000 ! init ! wall 0.006952 comb 0.010000 user 0.010000 sys 0.000000 (best of 418) ! gets ! wall 0.613350 comb 0.610000 user 0.610000 sys 0.000000 (best of 17) ! wall 0.617415 comb 0.620000 user 0.620000 sys 0.000000 (best of 17) ! inserts ! wall 0.701270 comb 0.700000 user 0.700000 sys 0.000000 (best of 15) ! wall 0.700516 comb 0.700000 user 0.700000 sys 0.000000 (best of 15) ! sets ! wall 0.825720 comb 0.830000 user 0.830000 sys 0.000000 (best of 13) ! wall 0.837946 comb 0.840000 user 0.830000 sys 0.010000 (best of 12) ! mixed ! wall 0.821644 comb 0.820000 user 0.820000 sys 0.000000 (best of 13) ! wall 0.850559 comb 0.850000 user 0.850000 sys 0.000000 (best of 12) I reckon the slight slowdown on insert is due to added if checks. For caches with total cost limiting enabled: $ hg perflrucachedict --size 4 --gets 1000000 --sets 1000000 --mixed 1000000 --costlimit 100 ! gets w/ cost limit ! wall 0.598737 comb 0.590000 user 0.590000 sys 0.000000 (best of 17) ! inserts w/ cost limit ! wall 1.694282 comb 1.700000 user 1.700000 sys 0.000000 (best of 6) ! mixed w/ cost limit ! wall 1.157655 comb 1.150000 user 1.150000 sys 0.000000 (best of 9) $ hg perflrucachedict --size 1000 --gets 1000000 --sets 1000000 --mixed 1000000 --costlimit 10000 ! gets w/ cost limit ! wall 0.598526 comb 0.600000 user 0.600000 sys 0.000000 (best of 17) ! inserts w/ cost limit ! wall 37.838315 comb 37.840000 user 37.840000 sys 0.000000 (best of 3) ! mixed w/ cost limit ! wall 18.060198 comb 18.060000 user 18.060000 sys 0.000000 (best of 3) $ hg perflrucachedict --size 1000 --gets 1000000 --sets 1000000 --mixed 1000000 --costlimit 10000 --mixedgetfreq 90 ! gets w/ cost limit ! wall 0.600024 comb 0.600000 user 0.600000 sys 0.000000 (best of 17) ! inserts w/ cost limit ! wall 37.154547 comb 37.120000 user 37.120000 sys 0.000000 (best of 3) ! mixed w/ cost limit ! wall 4.381602 comb 4.380000 user 4.370000 sys 0.010000 (best of 3) The functions we're benchmarking are slightly different, which could move numbers by a few milliseconds. But the slowdown on insert is too great to be explained by that. The slowness is due to insert heavy operations needing to call popoldest() repeatedly when the cache is at capacity. The next commit will address this. Differential Revision: https://phab.mercurial-scm.org/D4503

#require test-repo py3exe
  $ . "$TESTDIR/helpers-testrepo.sh"

  $ cd $TESTDIR/..
  $ python3 contrib/relnotes 4.4 --stoprev 4.5
  changeset 3398603c5621: unexpected block in release notes directive feature
  New Features
  ============
  
  revert --interactive
  --------------------
  
  The revert command now accepts the flag --interactive to allow reverting only
  some of the changes to the specified files.
  
  Rebase with different destination per source revision
  -----------------------------------------------------
  
  Previously, rebase only supports one unique destination. Now "SRC" and
  "ALLSRC" can be used in rebase destination revset to precisely define
  destination per each individual source revision.
  
  For example, the following command could move some orphaned changesets to
  reasonable new places so they become no longer orphaned:
  
  hg rebase   -r 'orphan()-obsolete()'   -d 'max((successors(max(roots(ALLSRC) &
  ::SRC)^)-obsolete())::)'
  
  Accessing hidden changesets
  ---------------------------
  
  Set config option 'experimental.directaccess = True' to access hidden
  changesets from read only commands.
  
  githelp extension
  -----------------
  
  The "githelp" extension provides the "hg githelp" command. This command
  attempts to convert a "git" command to its Mercurial equivalent. The extension
  can be useful to Git users new to Mercurial.
  
  Other Changes
  -------------
  
  * When interactive revert is run against a revision other than the working
    directory parent, the diff shown is the diff to *apply* to the working
    directory, rather than the diff to *discard* from the working copy. This is
    in line with related user experiences with 'git' and appears to be less
    confusing with 'ui.interface=curses'.
  
  * Let 'hg rebase' avoid content-divergence by skipping obsolete changesets
    (and their descendants) when they are present in the rebase set along with
    one of their successors but none of their successors is in destination.
  
  * hgweb now displays phases of non-public changesets
  
  * The "HGPLAINEXCEPT" environment variable can now include "color" to allow
    automatic output colorization in otherwise automated environments.
  
  * A new unamend command in uncommit extension which undoes the effect of the
    amend command by creating a new changeset which was there before amend and
    moving the changes that were amended to the working directory.
  
  * A '--abort' flag to merge command to abort the ongoing merge.
  
  * An experimental flag '--rev' to 'hg branch' which can be used to change
    branch of changesets.
  
  Backwards Compatibility Changes
  ===============================
  
  * "log --follow-first -rREV", which is deprecated, now follows the first
    parent of merge revisions from the specified "REV" just like "log --follow
    -rREV".
  
  * "log --follow -rREV FILE.." now follows file history across copies and
    renames.
  
  Bug Fixes
  =========
  
  Issue 5165
  ----------
  
  Bookmark, whose name is longer than 255, can again be exchanged again between
  4.4+ client and servers.
  
  Performance Improvements
  ========================
  
  * bundle2 read I/O throughput significantly increased.
  
  * Significant memory use reductions when reading from bundle2 bundles.
  
    On the BSD repository, peak RSS during changegroup application decreased by
    ~185 MB from ~752 MB to ~567 MB.
  
  API Changes
  ===========
  
  * bundlerepo.bundlerepository.bundle and
    bundlerepo.bundlerepository.bundlefile are now prefixed with an underscore.
  
  * Rename bundlerepo.bundlerepository.bundlefilespos to _cgfilespos.
  
  * dirstate no longer provides a 'dirs()' method.  To test for the existence of
    a directory in the dirstate, use 'dirstate.hasdir(dirname)'.
  
  * bundle2 parts are no longer seekable by default.
  
  * mapping does not contain all template resources. use context.resource() in
    template functions.
  
  * "text=False|True" option is dropped from the vfs interface because of Python
    3 compatibility issue. Use "util.tonativeeol/fromnativeeol()" to convert EOL
    manually.
  
  * wireproto.streamres.__init__ no longer accepts a "reader" argument. Use the
    "gen" argument instead.
  
  * exchange.getbundlechunks() now returns a 2-tuple instead of just an
    iterator.
  
  
  === commands ===
   * amend: do not drop missing files (Bts:issue5732)
   * amend: do not take untracked files as modified or clean (Bts:issue5732)
   * amend: update .hgsubstate before committing a memctx (Bts:issue5677)
   * annotate: add support to specify hidden revs if directaccess config is set
   * bookmark: add methods to binary encode and decode bookmark values
   * bookmark: deprecate direct update of a bookmark value
   * bookmark: introduce a 'bookmarks' part
   * bookmark: introduce in advance a variant of the exchange test
   * bookmark: run 'pushkey' hooks after bookmark move, not 'prepushkey'
   * bookmarks: add bookmarks to hidden revs if directaccess config is set
   * bookmarks: calculate visibility exceptions only once
   * bookmarks: display the obsfate of hidden revision we create a bookmark on
   * bookmarks: fix pushkey compatibility mode (Bts:issue5777)
   * bookmarks: use context managers for lock and transaction in update()
   * bookmarks: use context managers for locks and transaction in pushbookmark()
   * branch: allow changing branch name to existing name if possible
   * clone: add support for storing remotenames while cloning
   * clone: use utility function to write hgrc
   * clonebundle: make it possible to retrieve the initial bundle through largefile
   * commandserver: restore cwd in case of exception
   * commandserver: unblock SIGCHLD
   * help: deprecate ui.slash in favor of slashpath template filter (Bts:issue5572)
   * log: allow matchfn to be non-null even if both --patch/--stat are off
   * log: build follow-log filematcher at once
   * log: don't expand aliases in revset built from command options
   * log: make "slowpath" condition slightly more readable
   * log: make opt2revset table a module constant
   * log: merge getlogrevs() and getgraphlogrevs()
   * log: remove temporary variable 'date' used only once
   * log: resolve --follow thoroughly in getlogrevs()
   * log: resolve --follow with -rREV in cmdutil.getlogrevs()
   * log: simplify 'x or ancestors(x)' expression
   * log: translate column labels at once (Bts:issue5750)
   * log: use revsetlang.formatspec() thoroughly
   * log: use revsetlang.formatspec() to concatenate list expression
   * log: use smartset.slice() to limit number of revisions to be displayed
   * merge: cache unknown dir checks (Bts:issue5716)
   * merge: check created file dirs for path conflicts only once (Bts:issue5716)
   * patch: add within-line color diff capacity
   * patch: catch unexpected case in _inlinediff
   * patch: do not break up multibyte character when highlighting word
   * patch: improve heuristics to not take the word "diff" as header (Bts:issue1879)
   * patch: reverse _inlinediff output for consistency
   * pull: clarify that -u only updates linearly
   * pull: hold wlock for the full operation when --update is used
   * pull: retrieve bookmarks through the binary part when possible
   * pull: store binary node in pullop.remotebookmarks
   * push: include a 'check:bookmarks' part when possible
   * push: restrict common discovery to the pushed set
   * revert: support reverting to hidden cset if directaccess config is set
  
  === core ===
   * filelog: add the ability to report the user facing name
   * revlog: choose between ifh and dfh once for all
   * revlog: don't use slicing to return parents
   * revlog: group delta computation methods under _deltacomputer object
   * revlog: group revision info into a dedicated structure
   * revlog: introduce 'deltainfo' to distinguish from 'delta'
   * revlog: rename 'rev' to 'base', as it is the base revision
   * revlog: separate diff computation from the collection of other info
   * revset: evaluate filesets against each revision for 'file()' (Bts:issue5778)
   * revset: parse x^:: as (x^):: (Bts:issue5764)
   * templater: look up symbols/resources as if they were separated (Bts:issue5699)
   * transaction: register summary callbacks only at start of transaction (BC)
   * util: whitelist NTFS for hardlink creation (Bts:issue4580)
  
  === extensions ===
   * convert: restore the ability to use bzr < 2.6.0 (Bts:issue5733)
   * histedit: add support to output nodechanges using formatter
   * largefiles: add a 'debuglfput' command to put largefile into the store
   * largefiles: add support for 'largefiles://' url scheme
   * largefiles: allow to run 'debugupgraderepo' on repo with largefiles
   * largefiles: convert EOL of hgrc before appending to bytes IO
   * largefiles: explicitly set the source and sink types to 'hg' for lfconvert
   * largefiles: modernize how capabilities are added to the wire protocol
   * largefiles: pay attention to dropped standin files when updating largefiles
   * rebase: add concludememorynode(), and call it when rebasing in-memory
   * rebase: add the --inmemory option flag; assign a wctx object for the rebase
   * rebase: add ui.log calls for whether IMM used, whether rebasing WCP
   * rebase: disable 'inmemory' if the rebaseset contains the working copy
   * rebase: do not bail on uncomitted changes if rebasing in-memory
   * rebase: do not update if IMM; instead, set the overlaywctx's parents
   * rebase: don't run IMM if running rebase in a transaction
   * rebase: don't take out a dirstate guard for in-memory rebase
   * rebase: drop --style option
   * rebase: fix for hgsubversion
   * rebase: pass the wctx object (IMM or on-disk) to merge.update
   * rebase: pass wctx to rebasenode()
   * rebase: rerun a rebase on-disk if IMM merge conflicts arise
   * rebase: switch ui.log calls to common style
   * rebase: use fm.formatlist() and fm.formatdict() to support user template
  
  === hgweb ===
   * hgweb: disable diff.noprefix option for diffstat
   * hgweb: drop support of browsers that don't understand <canvas> (BC)
   * hgweb: only include graph-related data in jsdata variable on /graph pages (BC)
   * hgweb: stop adding strings to innerHTML of #graphnodes and #nodebgs (BC)
  
  === unsorted ===
   * archive: add support to specify hidden revs if directaccess config is set
   * atomicupdate: add an experimental option to use atomictemp when updating
   * bundle: allow bundlerepo to support alternative manifest implementations
   * changelog: introduce a 'tiprev' method
   * changelog: use 'tiprev()' in 'tip()'
   * completion: add support for new "amend" command
   * debugssl: convert port number to int (Bts:issue5757)
   * diff: disable diff.noprefix option for diffstat (Bts:issue5759)
   * dispatch: abort if early boolean options can't be parsed
   * dispatch: add HGPLAIN=+strictflags to restrict early parsing of global options
   * dispatch: add option to not strip command args parsed by _earlygetopt()
   * dispatch: alias --repo to --repository while parsing early options
   * dispatch: convert non-list option parsed by _earlygetopt() to string
   * dispatch: fix early parsing of short option with value like -R=foo
   * dispatch: handle IOError when writing to stderr
   * dispatch: stop parsing of early boolean option at "--"
   * dispatch: verify result of early command parsing
   * evolution: make reporting of new unstable changesets optional
   * extdata: abort if external command exits with non-zero status (BC)
   * fancyopts: add early-options parser compatible with getopt()
   * graphlog: add another graph node type, unstable, using character "*" (BC)
   * hgdemandimport: use correct hyperlink to python-bug in comments (Bts:issue5765)
   * httppeer: add support for tracing all http request made by the peer
   * identify: document -r. explicitly how to disable wdir scanning (Bts:issue5622)
   * lfs: register config options
   * localrepo: specify optional callback parameter to pathauditor as a keyword
   * match: do not weirdly include explicit files excluded by -X option
   * memfilectx: make changectx argument mandatory in constructor (API)
   * morestatus: don't crash with different drive letters for repo.root and CWD
   * outgoing: respect ":pushurl" paths (Bts:issue5365)
   * remove: print message for each file in verbose mode only while using '-A' (BC)
   * rewriteutil: use precheck() in uncommit and amend commands
   * scmutil: don't try to delete origbackup symlinks to directories (Bts:issue5731)
   * sshpeer: add support for request tracing
   * streamclone: add support for bundle2 based stream clone
   * streamclone: add support for cloning non append-only file
   * streamclone: also stream caches to the client
   * streamclone: define first iteration of version 2 of stream format
   * streamclone: move wire protocol status code from wireproto command
   * streamclone: rework canperformstreamclone
   * streamclone: tests phase exchange during stream clone
   * streamclone: use readexactly when reading stream v2
   * subrepo: add config option to reject any subrepo operations (SEC)
   * subrepo: disable git and svn subrepos by default (BC) (SEC)
   * subrepo: extend config option to disable subrepos by type (SEC)
   * subrepo: handle 'C:' style paths on the command line (Bts:issue5770)
   * subrepo: use per-type config options to enable subrepos
   * svnsubrepo: check if subrepo is missing when checking dirty state (Bts:issue5657)
   * tr-summary: keep a weakref to the unfiltered repository
   * unamend: fix command summary line
   * uncommit: unify functions _uncommitdirstate and _unamenddirstate to one
   * update: support updating to hidden cset if directaccess config is set
  
  === BC ===
  
   * extdata: abort if external command exits with non-zero status (BC)
   * graphlog: add another graph node type, unstable, using character "*" (BC)
   * hgweb: drop support of browsers that don't understand <canvas> (BC)
   * hgweb: only include graph-related data in jsdata variable on /graph pages (BC)
   * hgweb: stop adding strings to innerHTML of #graphnodes and #nodebgs (BC)
   * remove: print message for each file in verbose mode only while using '-A' (BC)
   * subrepo: disable git and svn subrepos by default (BC) (SEC)
   * transaction: register summary callbacks only at start of transaction (BC)
  
  === API Changes ===
  
   * memfilectx: make changectx argument mandatory in constructor (API)