NAME

Dist::Zilla::Plugin::Test::MixedScripts - author tests to ensure there is no mixed Unicode

VERSION

version v0.2.3

SYNOPSIS

In the dist.ini add:

[Test::MixedScripts]
; authordep Test::MixedScripts
script = Latin
script = Common

DESCRIPTION

This generates an author Test::MixedScripts.

This is an extension of Dist::Zilla::Plugin::InlineFiles, providing the file xt/author/mixed-unicode-scripts.t for testing against mixed Unicode scripts that are potentially confusing or malicious.

For example, the text for the domain names оnе.example.com and one.example.com look indistinguishable in many fonts, but the first one has Cyrillic letters. If your software interacted with a service on the second domain, then someone can operate a service on the first domain and attempt to fool developers into using their domain instead.

This might be through a malicious patch submission, or even text from an email or web page that they have convinced a developer to copy and paste into their code.

CONFIGURATION OPTIONS

filename

This is the filename of the test to add. Defaults to xt/author/mixed-unicode-scripts.t.

finder

This is the name of a FileFinder for finding files to check. The default value is :InstallModules, :ExecFiles (see also Dist::Zilla::Plugin::ExecDir) and :TestFiles.

This option can be used more than once.

Other predefined finders are listed in "default_finders" in Dist::Zilla::Role::FileFinderUser. You can define your own with the FileFinder::ByName plugin.

file

This is a filename to also test, in addition to any files found earlier.

This option can be repeated to specify multiple additional files.

exclude

This is a regular expression of filenames to exclude.

This option can be repeated to specify multiple patterns.

script

This specifies the scripts to test for. If none are specified, it defaults to the defaults for Test::MixedScripts.

KNOWN ISSUES

The default "finder" does not include XS-related files. You will have to add them manually using the "file" option, for example, in the dist.ini:

[Test::MixedScripts]
file = XS.xs
file = XS.c

SUPPORT

Only the latest version of this module will be supported.

This module requires Perl v5.20 or later. Future releases may only support Perl versions released in the last ten years.

Reporting Bugs and Submitting Feature Requests

Please report any bugs or feature requests on the bugtracker website https://github.com/robrwo/perl-Dist-Zilla-Plugin-Test-MixedScripts/issues

When submitting a bug or request, please include a test-file or a patch to an existing test-file that illustrates the bug or desired feature.

If the bug you are reporting has security implications which make it inappropriate to send to a public issue tracker, then see SECURITY.md for instructions how to report security vulnerabilities.

SOURCE

The development version is on github at https://github.com/robrwo/perl-Dist-Zilla-Plugin-Test-MixedScripts and may be cloned from git://github.com/robrwo/perl-Dist-Zilla-Plugin-Test-MixedScripts.git

AUTHOR

Robert Rothenberg <rrwo@cpan.org>

This code was based on Dist::Zilla::Plugin::Test::EOL by Florian Ragwitz <rafl@debian.org>, Caleb Cushing <xenoterracide@gmail.com> and Karen Etheridge <ether@cpan.org>.

CONTRIBUTOR

Graham Knop <haarg@haarg.org>

COPYRIGHT AND LICENSE

This software is copyright (c) 2025 by Robert Rothenberg.

This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.