Test for Windows encoding issue #13787

pull ken2812221 wants to merge 2 commits into bitcoin:master from ken2812221:test_u8path changing 2 files +1 −4
  1. ken2812221 commented at 6:05 pm on July 28, 2018: contributor
    This PR removes unused Windows compatible path. Encoding issues has been solved.
  2. DrahtBot commented at 7:54 pm on July 28, 2018: member

    The following sections might be updated with supplementary metadata relevant to reviewers and maintainers.

    Conflicts

    No conflicts as of last run.

  3. ken2812221 force-pushed on Jul 30, 2018
  4. ken2812221 force-pushed on Jul 31, 2018
  5. ken2812221 force-pushed on Jul 31, 2018
  6. ken2812221 force-pushed on Jul 31, 2018
  7. ken2812221 force-pushed on Jul 31, 2018
  8. MarcoFalke added this to the milestone 0.18.0 on Aug 2, 2018
  9. ken2812221 force-pushed on Aug 5, 2018
  10. ken2812221 renamed this:
    Test for #13426
    Test for #13869
    on Aug 5, 2018
  11. ken2812221 force-pushed on Aug 6, 2018
  12. ken2812221 force-pushed on Aug 6, 2018
  13. ken2812221 force-pushed on Aug 10, 2018
  14. ken2812221 force-pushed on Aug 11, 2018
  15. ken2812221 force-pushed on Aug 11, 2018
  16. DrahtBot added the label Needs rebase on Aug 15, 2018
  17. jnewbery commented at 2:15 pm on August 23, 2018: member
    suggest you update the title to describe what’s being tested (rather than referencing a different issue)
  18. ken2812221 renamed this:
    Test for #13869
    Test for Windows encoding issue
    on Aug 24, 2018
  19. ken2812221 commented at 3:22 am on August 24, 2018: contributor
    @jnewbery Thanks for your suggestion
  20. ken2812221 force-pushed on Aug 29, 2018
  21. ken2812221 force-pushed on Aug 29, 2018
  22. DrahtBot removed the label Needs rebase on Aug 29, 2018
  23. sipsorcery commented at 11:39 am on August 31, 2018: member

    Without this PR bitcoind does not get very far with a unicode directory (the conf file uses datadir=C:\Temp\资金钱包\Bitcoin) :

    bitcoind -conf=c:\temp\bitcoin.conf Error reading configuration file: specified data directory “C:\Temp\ÞÁäÚçæÚÆ▒Õîà\Bitcoin” does not exist.

    After applying this PR bitcoind gets to the point where it attempts to open the wallet file:

    bitcoind -conf=c:\temp\bitcoin.conf 2018-08-31T11:22:29Z Bitcoin Core version v1.17.99.0-unk (release build) 2018-08-31T11:22:30Z InitParameterInteraction: parameter interaction: -whitelistforcerelay=1 -> setting -whitelistrelay=1 2018-08-31T11:22:30Z Validating signatures for all blocks. 2018-08-31T11:22:30Z Setting nMinimumChainWork=0000000000000000000000000000000000000000000000000000000000000000 2018-08-31T11:22:30Z Using the ‘standard’ SHA256 implementation 2018-08-31T11:22:31Z Default data directory C:\Users\aaron\AppData\Roaming\Bitcoin 2018-08-31T11:22:31Z Using data directory C:\Temp\ÞÁäÚçæÚÆ▒Õîà\Bitcoin\regtest 2018-08-31T11:22:31Z Using config file c:\temp\bitcoin.conf …. 2018-08-31T11:22:32Z Using wallet wallet.dat 2018-08-31T11:22:32Z BerkeleyEnvironment::Open: LogDir=C:\Temp\ÞÁäÚçæÚÆ▒Õîà\Bitcoin\regtest\wallets\database ErrorFile=C:\Temp\ÞÁäÚçæÚÆ▒Õîà\Bitcoin\regtest\wallets\db.log 2018-08-31T11:22:32Z BerkeleyEnvironment::Open: Error -30974 opening database environment: DB_RUNRECOVERY: Fatal error, run database recovery 2018-08-31T11:22:32Z Moved old C:\Temp\ÞÁäÚçæÚÆ▒Õîà\Bitcoin\regtest\wallets\database to C:\Temp\ÞÁäÚçæÚÆ▒Õîà\Bitcoin\regtest\wallets\database.1535714552.bak. Retrying. 2018-08-31T11:22:32Z BerkeleyEnvironment::Open: LogDir=C:\Temp\ÞÁäÚçæÚÆ▒Õîà\Bitcoin\regtest\wallets\database ErrorFile=C:\Temp\ÞÁäÚçæÚÆ▒Õîà\Bitcoin\regtest\wallets\db.log 2018-08-31T11:22:32Z BerkeleyEnvironment::Open: Error -30974 opening database environment: DB_RUNRECOVERY: Fatal error, run database recovery 2018-08-31T11:22:32Z Error: Error initializing wallet database environment “C:\Temp\ÞÁäÚçæÚÆ▒Õîà\Bitcoin\regtest\wallets”! Error: Error initializing wallet database environment “C:\Temp\ÞÁäÚçæÚÆ▒Õîà\Bitcoin\regtest\wallets”!

    I’ll work out how to apply the leveldb patch and retry.

  24. ken2812221 force-pushed on Aug 31, 2018
  25. ken2812221 commented at 2:43 pm on August 31, 2018: contributor

    @sipsorcery Thanks for testing. Could you test this again? This shall not contain garbled text.

    However, I didn’t get that bdb error locally. Did you forget to make -C depends HOST=x86_64-w64-mingw32? This should re-compile the bdb to support unicode.

  26. sipsorcery commented at 8:09 am on September 1, 2018: member

    @ken2812221 I’m testing with a Visual Studio build (currently having difficulty running the mingw32 build to run due to something being up with libzmq; still tracking that one down).

    I’ve added leveldb to my VS solution and patched it. Bitcoind now seems to work correctly with unicode characters in the data directory path IF the wallet is disabled. If the wallet is enabled then the BerkleyDB library is failing to initialise.

    2018-09-01T07:37:21Z BerkeleyEnvironment::Open: LogDir=C:\Temp\资金钱包\Bitcoin\regtest\wallets\database ErrorFile=C:\Temp\资金钱包\Bitcoin\regtest\wallets\db.log 2018-09-01T07:37:21Z BerkeleyEnvironment::Open: Error -30974 opening database environment: DB_RUNRECOVERY: Fatal error, run database recovery 2018-09-01T07:37:21Z Moved old C:\Temp\资金钱包\Bitcoin\regtest\wallets\database to C:\Temp\资金钱包\Bitcoin\regtest\wallets\database.1535787441.bak. Retrying. 2018-09-01T07:37:21Z BerkeleyEnvironment::Open: LogDir=C:\Temp\资金钱包\Bitcoin\regtest\wallets\database ErrorFile=C:\Temp\资金钱包\Bitcoin\regtest\wallets\db.log 2018-09-01T07:37:21Z BerkeleyEnvironment::Open: Error -30974 opening database environment: DB_RUNRECOVERY: Fatal error, run database recovery 2018-09-01T07:37:23Z Error: Error initializing wallet database environment “C:\Temp\资金钱包\Bitcoin\regtest\wallets”! Error: Error initializing wallet database environment “C:\Temp\2018-09-01T07:37:44Z Interrupting HTTP RPC server 2018-09-01T07:37:44Z Interrupting RPC

    Kudos for working on this! Unicode and Windows is a minefield. Have you seen http://utf8everywhere.org/ (Chapter 10 is dedicated to UTF on Windows).

  27. ken2812221 commented at 12:51 pm on September 1, 2018: contributor
    You can see #13884 , I pre-defined UNICODE and _UNICODE. You should define them while you are compiling berkeleydb. But I don’t know how to do that with vcpkg.
  28. sipsorcery commented at 7:12 pm on September 2, 2018: member

    I’ve built this PR on Ubuntu and Windows Subsystem for Linux (Ubuntu 18) and bitcoind executes correctly with a data directory that contains unicode characters.

    I am not familiar with nsis and have not tested that part of the PR. How do I use nsis to the build the installer package?

    One additional task that would need to be done after this PR is merged is to update the Windows build instructions to add the new packages:

    sudo apt install scons wine-binfmt wine64 g++-mingw-w64-i686

  29. ken2812221 force-pushed on Sep 7, 2018
  30. ken2812221 force-pushed on Sep 7, 2018
  31. ken2812221 force-pushed on Sep 12, 2018
  32. laanwj added the label Tests on Sep 13, 2018
  33. laanwj added the label Windows on Sep 13, 2018
  34. DrahtBot added the label Needs rebase on Sep 13, 2018
  35. ken2812221 force-pushed on Sep 13, 2018
  36. ken2812221 force-pushed on Sep 13, 2018
  37. DrahtBot removed the label Needs rebase on Sep 13, 2018
  38. ken2812221 force-pushed on Sep 16, 2018
  39. ken2812221 force-pushed on Sep 16, 2018
  40. ken2812221 force-pushed on Sep 27, 2018
  41. ken2812221 force-pushed on Sep 27, 2018
  42. ken2812221 force-pushed on Sep 28, 2018
  43. ken2812221 force-pushed on Sep 28, 2018
  44. ken2812221 force-pushed on Sep 28, 2018
  45. ken2812221 force-pushed on Sep 30, 2018
  46. in test/functional/test_runner.py:255 in 0131f56dd8 outdated
    243@@ -244,10 +244,6 @@ def main():
    244     # Create base test directory
    245     tmpdir = "%s/test_runner_₿_🏃_%s" % (args.tmpdirprefix, datetime.datetime.now().strftime("%Y%m%d_%H%M%S"))
    246 
    247-    # If we fixed the command-line and filename encoding issue on Windows, these two lines could be removed
    248-    if config["environment"]["EXEEXT"] == ".exe":
    249-        tmpdir = "%s/test_runner_%s" % (args.tmpdirprefix, datetime.datetime.now().strftime("%Y%m%d_%H%M%S"))
    


    MarcoFalke commented at 0:57 am on October 1, 2018:
    Nice
  47. DrahtBot added the label Needs rebase on Oct 8, 2018
  48. ken2812221 force-pushed on Oct 8, 2018
  49. DrahtBot removed the label Needs rebase on Oct 8, 2018
  50. DrahtBot added the label Needs rebase on Nov 5, 2018
  51. ken2812221 force-pushed on Nov 5, 2018
  52. DrahtBot removed the label Needs rebase on Nov 5, 2018
  53. DrahtBot added the label Needs rebase on Nov 7, 2018
  54. ken2812221 force-pushed on Nov 8, 2018
  55. DrahtBot removed the label Needs rebase on Nov 8, 2018
  56. ken2812221 force-pushed on Nov 8, 2018
  57. ken2812221 force-pushed on Jan 22, 2019
  58. ken2812221 force-pushed on Jan 22, 2019
  59. ken2812221 force-pushed on Jan 22, 2019
  60. laanwj referenced this in commit f545dfabff on Jan 26, 2019
  61. DrahtBot added the label Needs rebase on Jan 31, 2019
  62. MarcoFalke removed the label Needs rebase on Jan 31, 2019
  63. DrahtBot added the label Needs rebase on Jan 31, 2019
  64. laanwj commented at 3:49 pm on February 6, 2019: member
    Looks like most of the prerequisites have been merged now, can we make this in before the 0.18 split?
  65. ken2812221 commented at 9:12 am on February 7, 2019: contributor
    Appveyor is going to update the images in a few days. After then, we don’t have to get the latest vapkg port data to get Berkeley db package and re-build vcpkg every time (3+ minutes). I will rebase it once they update the CI image.
  66. tests: accept unicode characters on Windows ae892adceb
  67. ken2812221 force-pushed on Feb 11, 2019
  68. DrahtBot removed the label Needs rebase on Feb 11, 2019
  69. appveyor: Remove outdated libraries 15b31032a6
  70. ken2812221 force-pushed on Feb 11, 2019
  71. laanwj commented at 12:56 pm on February 12, 2019: member
    Ok, just be aware that the split is going to be 2019-03-01 and it’s going to be busy around then.
  72. ken2812221 commented at 1:04 pm on February 12, 2019: contributor
    This is ready to review/merge. I have already rebased it.
  73. MarcoFalke merged this on Feb 12, 2019
  74. MarcoFalke closed this on Feb 12, 2019

  75. MarcoFalke referenced this in commit d8794a78a8 on Feb 12, 2019
  76. ken2812221 deleted the branch on Feb 13, 2019
  77. jasonbcox referenced this in commit 6b6adaedc7 on Nov 10, 2020
  78. linuxsh2 referenced this in commit 4b94a052d0 on Sep 16, 2021
  79. Munkybooty referenced this in commit 1ac603aa07 on Oct 5, 2021
  80. Munkybooty referenced this in commit ee875183ff on Oct 5, 2021
  81. Munkybooty referenced this in commit 5cc78ce06b on Oct 7, 2021
  82. pravblockc referenced this in commit d8b1e933c3 on Nov 18, 2021
  83. MarcoFalke locked this on Dec 16, 2021

github-metadata-mirror

This is a metadata mirror of the GitHub repository bitcoin/bitcoin. This site is not affiliated with GitHub. Content is generated from a GitHub metadata backup.
generated: 2024-07-01 13:12 UTC

This site is hosted by @0xB10C
More mirrored repositories can be found on mirror.b10c.me