contrib / hooks / multimail / doc / troubleshooting.rston commit Merge branch 'bc/hash-independent-tests-part-4' (fcdd9cc)
   1Troubleshooting issues with git-multimail: a FAQ
   2================================================
   3
   4How to check that git-multimail is properly set up?
   5---------------------------------------------------
   6
   7Since version 1.4.0, git-multimail allows a simple self-checking of
   8its configuration: run it with the environment variable
   9``GIT_MULTIMAIL_CHECK_SETUP`` set to a non-empty string. You should
  10get something like this::
  11
  12  $ GIT_MULTIMAIL_CHECK_SETUP=true /home/moy/dev/git-multimail/git-multimail/git_multimail.py
  13  Environment values:
  14      administrator : 'the administrator of this repository'
  15      charset : 'utf-8'
  16      emailprefix : '[git-multimail] '
  17      fqdn : 'anie'
  18      projectdesc : 'UNNAMED PROJECT'
  19      pusher : 'moy'
  20      repo_path : '/home/moy/dev/git-multimail'
  21      repo_shortname : 'git-multimail'
  22
  23  Now, checking that git-multimail's standard input is properly set ...
  24  Please type some text and then press Return
  25  foo
  26  You have just entered:
  27  foo
  28  git-multimail seems properly set up.
  29
  30If you forgot to set an important variable, you may get instead::
  31
  32  $ GIT_MULTIMAIL_CHECK_SETUP=true /home/moy/dev/git-multimail/git-multimail/git_multimail.py
  33  No email recipients configured!
  34
  35Do not set ``$GIT_MULTIMAIL_CHECK_SETUP`` other than for testing your
  36configuration: it would disable the hook completely.
  37
  38Git is not using the right address in the From/To/Reply-To field
  39----------------------------------------------------------------
  40
  41First, make sure that git-multimail actually uses what you think it is
  42using. A lot happens to your email (especially when posting to a
  43mailing-list) between the time `git_multimail.py` sends it and the
  44time it reaches your inbox.
  45
  46A simple test (to do on a test repository, do not use in production as
  47it would disable email sending): change your post-receive hook to call
  48`git_multimail.py` with the `--stdout` option, and try to push to the
  49repository. You should see something like::
  50
  51  Counting objects: 3, done.
  52  Writing objects: 100% (3/3), 263 bytes | 0 bytes/s, done.
  53  Total 3 (delta 0), reused 0 (delta 0)
  54  remote: Sending notification emails to: foo.bar@example.com
  55  remote: ===========================================================================
  56  remote: Date: Mon, 25 Apr 2016 18:39:59 +0200
  57  remote: To: foo.bar@example.com
  58  remote: Subject: [git] branch master updated: foo
  59  remote: MIME-Version: 1.0
  60  remote: Content-Type: text/plain; charset=utf-8
  61  remote: Content-Transfer-Encoding: 8bit
  62  remote: Message-ID: <20160425163959.2311.20498@anie>
  63  remote: From: Auth Or <Foo.Bar@example.com>
  64  remote: Reply-To: Auth Or <Foo.Bar@example.com>
  65  remote: X-Git-Host: example
  66  ...
  67  remote: --
  68  remote: To stop receiving notification emails like this one, please contact
  69  remote: the administrator of this repository.
  70  remote: ===========================================================================
  71  To /path/to/repo
  72     6278f04..e173f20  master -> master
  73
  74Note: this does not include the sender (Return-Path: header), as it is
  75not part of the message content but passed to the mailer. Some mailer
  76show the ``Sender:`` field instead of the ``From:`` field (for
  77example, Zimbra Webmail shows ``From: <sender-field> on behalf of
  78<from-field>``).