using System.Runtime.Serialization;
using System.Text;
using System.Windows.Forms;
-using NSubstitute;
+using Moq;
using OpenTween;
+using OpenTween.Models;
using Xunit;
using Xunit.Extensions;
public class MyCommonTest
{
[Theory]
- [InlineData("http://ja.wikipedia.org/wiki/Wikipedia", "http://ja.wikipedia.org/wiki/Wikipedia")]
- [InlineData("http://ja.wikipedia.org/wiki/メインページ",
- "http://ja.wikipedia.org/wiki/%E3%83%A1%E3%82%A4%E3%83%B3%E3%83%9A%E3%83%BC%E3%82%B8")]
- [InlineData("http://fr.wikipedia.org/wiki/Café", "http://fr.wikipedia.org/wiki/Caf%E9")]
- [InlineData("http://ja.wikipedia.org/wiki/勇気100%", "http://ja.wikipedia.org/wiki/%E5%8B%87%E6%B0%97100%25")]
- [InlineData("http://ja.wikipedia.org/wiki/Bio_100%", "http://ja.wikipedia.org/wiki/Bio_100%25")]
- public void urlEncodeMultibyteCharTest(string uri, string expected)
- {
- Assert.Equal(expected, MyCommon.urlEncodeMultibyteChar(uri));
- }
-
- [Theory]
[InlineData("http://日本語.idn.icann.org/", "http://xn--wgv71a119e.idn.icann.org/")]
[InlineData("http://例え.テスト/", "http://xn--r8jz45g.xn--zckzah/")]
public void IDNEncodeTest(string uri, string expected)
- {
- Assert.Equal(expected, MyCommon.IDNEncode(uri));
- }
+ => Assert.Equal(expected, MyCommon.IDNEncode(uri));
[Theory]
[InlineData("http://xn--wgv71a119e.idn.icann.org/", "http://日本語.idn.icann.org/")]
[InlineData("http://xn--r8jz45g.xn--zckzah/", "http://例え.テスト/")]
+ [InlineData("http://xn--a/", "http://xn--a/")] // 不正なpunycode
public void IDNDecodeTest(string uri, string expected)
- {
- Assert.Equal(expected, MyCommon.IDNDecode(uri));
- }
+ => Assert.Equal(expected, MyCommon.IDNDecode(uri));
+
+ [Theory]
+ [InlineData("http://xn--r8jz45g.xn--zckzah/", "http://例え.テスト/")]
+ [InlineData("http://ja.wikipedia.org/wiki/%3F", "http://ja.wikipedia.org/wiki/%3F")] // "?" に変換しない
+ [InlineData("http://ja.wikipedia.org/wiki/%E3%83%9E%E3%82%B8LOVE1000%25",
+ "http://ja.wikipedia.org/wiki/マジLOVE1000%25")] // "%" も変換しない
+ [InlineData("http://xn--a/%E3%81%82", "http://xn--a/あ")] // 不正なpunycode
+ [InlineData("http://example..com/", "http://example..com/")] // 不正なURL
+ [InlineData("http://example.com/%E3%81%82%FF", "http://example.com/あ%FF")] // 不正なUTF-8シーケンス
+ [InlineData("http://example.com/%E3%81%82%ED%A0%80", "http://example.com/あ%ED%A0%80")] // 不正なUTF-8シーケンス (high surrogate)
+ public void ConvertToReadableUrl(string url, string expected)
+ => Assert.Equal(expected, MyCommon.ConvertToReadableUrl(url));
[Theory]
[InlineData(new int[] { 1, 2, 3, 4 }, 0, 3, new int[] { 2, 3, 4, 1 })] // 左ローテイト?
[InlineData(new byte[] { 0x01, 0x02 }, 2, new byte[] { 0x01, 0x02 })]
[InlineData(new byte[] { 0x01, 0x02 }, 1, new byte[] { 0x03 })]
public void ResizeBytesArrayTest(byte[] bytes, int size, byte[] expected)
- {
- Assert.Equal(expected, MyCommon.ResizeBytesArray(bytes, size));
- }
+ => Assert.Equal(expected, MyCommon.ResizeBytesArray(bytes, size));
[Theory]
[InlineData("Resources/re.gif", true)]
[InlineData("Resources/re1.gif", false)]
[InlineData("Resources/re1.png", false)]
public void IsAnimatedGifTest(string filename, bool expected)
- {
- Assert.Equal(expected, MyCommon.IsAnimatedGif(filename));
- }
+ => Assert.Equal(expected, MyCommon.IsAnimatedGif(filename));
- public static IEnumerable<object[]> DateTimeParse_TestCase
+ public static readonly TheoryData<string, DateTimeUtc> DateTimeParse_TestCase = new TheoryData<string, DateTimeUtc>
{
- get
- {
- yield return new object[] {
- "Sun Nov 25 06:10:00 +00:00 2012",
- new DateTime(2012, 11, 25, 6, 10, 0, DateTimeKind.Utc),
- };
- yield return new object[] {
- "Sun, 25 Nov 2012 06:10:00 +00:00",
- new DateTime(2012, 11, 25, 6, 10, 0, DateTimeKind.Utc),
- };
- }
- }
+ { "Sun Nov 25 06:10:00 +00:00 2012", new DateTimeUtc(2012, 11, 25, 6, 10, 0) },
+ { "Sun, 25 Nov 2012 06:10:00 +00:00", new DateTimeUtc(2012, 11, 25, 6, 10, 0) },
+ };
[Theory]
- [PropertyData("DateTimeParse_TestCase")]
- public void DateTimeParseTest(string date, DateTime excepted)
- {
- Assert.Equal(excepted, MyCommon.DateTimeParse(date).ToUniversalTime());
- }
+ [MemberData(nameof(DateTimeParse_TestCase))]
+ public void DateTimeParseTest(string date, DateTimeUtc excepted)
+ => Assert.Equal(excepted, MyCommon.DateTimeParse(date));
[DataContract]
public struct JsonData
[DataMember(Name = "id")] public string Id { get; set; }
[DataMember(Name = "body")] public string Body { get; set; }
}
- public static IEnumerable<object[]> CreateDataFromJson_TestCase
+ public static readonly TheoryData<string, JsonData> CreateDataFromJson_TestCase = new TheoryData<string, JsonData>
{
- get
{
- yield return new object[] {
- @"{""id"":""1"", ""body"":""hogehoge""}",
- new JsonData { Id = "1", Body = "hogehoge" },
- };
- }
- }
+ @"{""id"":""1"", ""body"":""hogehoge""}",
+ new JsonData { Id = "1", Body = "hogehoge" }
+ },
+ };
[Theory]
- [PropertyData("CreateDataFromJson_TestCase")]
+ [MemberData(nameof(CreateDataFromJson_TestCase))]
public void CreateDataFromJsonTest<T>(string json, T expected)
- {
- Assert.Equal(expected, MyCommon.CreateDataFromJson<T>(json));
- }
+ => Assert.Equal(expected, MyCommon.CreateDataFromJson<T>(json));
[Theory]
[InlineData("hoge123@example.com", true)]
[InlineData("foobar.@example.com", false)]
[InlineData("foo+bar@example.com", true)]
public void IsValidEmailTest(string email, bool expected)
- {
- Assert.Equal(expected, MyCommon.IsValidEmail(email));
- }
+ => Assert.Equal(expected, MyCommon.IsValidEmail(email));
[Theory]
[InlineData(Keys.Shift, new[] { Keys.Shift }, true)]
[InlineData(Keys.Control | Keys.Alt, new[] { Keys.Control, Keys.Alt }, true)]
[InlineData(Keys.Control | Keys.Alt, new[] { Keys.Shift }, false)]
public void IsKeyDownTest(Keys modifierKeys, Keys[] checkKeys, bool expected)
- {
- Assert.Equal(expected, MyCommon._IsKeyDown(modifierKeys, checkKeys));
- }
+ => Assert.Equal(expected, MyCommon._IsKeyDown(modifierKeys, checkKeys));
[Fact]
public void GetAssemblyNameTest()
{
- var mockAssembly = Substitute.For<_Assembly>();
- mockAssembly.GetName().Returns(new AssemblyName("OpenTween"));
- MyCommon.EntryAssembly = mockAssembly;
+ var mockAssembly = new Mock<_Assembly>();
+ mockAssembly.Setup(m => m.GetName()).Returns(new AssemblyName("OpenTween"));
+ MyCommon.EntryAssembly = mockAssembly.Object;
Assert.Equal("OpenTween", MyCommon.GetAssemblyName());
}
[InlineData("%AppName%", "OpenTween")]
[InlineData("%AppName% %AppName%", "OpenTween OpenTween")]
public void ReplaceAppNameTest(string str, string excepted)
- {
- Assert.Equal(excepted, MyCommon.ReplaceAppName(str, "OpenTween"));
- }
+ => Assert.Equal(excepted, MyCommon.ReplaceAppName(str, "OpenTween"));
[Theory]
[InlineData("1.0.0.0", "1.0.0")]
- [InlineData("1.0.0.1", "1.0.1-beta1")]
- [InlineData("1.0.0.9", "1.0.1-beta9")]
+ [InlineData("1.0.0.1", "1.0.1-dev")]
+ [InlineData("1.0.0.12", "1.0.1-dev+build.12")]
[InlineData("1.0.1.0", "1.0.1")]
- [InlineData("1.0.9.1", "1.1.0-beta1")]
+ [InlineData("1.0.9.1", "1.0.10-dev")]
[InlineData("1.1.0.0", "1.1.0")]
- [InlineData("1.9.9.1", "2.0.0-beta1")]
+ [InlineData("1.9.9.1", "1.9.10-dev")]
public void GetReadableVersionTest(string fileVersion, string expected)
- {
- Assert.Equal(expected, MyCommon.GetReadableVersion(fileVersion));
- }
+ => Assert.Equal(expected, MyCommon.GetReadableVersion(fileVersion));
- public static IEnumerable<object[]> GetStatusUrlTest1_TestCase
+ public static readonly TheoryData<PostClass, string> GetStatusUrlTest1_TestCase = new TheoryData<PostClass, string>
{
- get
{
- yield return new object[] {
- new PostClass { StatusId = 249493863826350080L, ScreenName = "Favstar_LM", RetweetedId = null, RetweetedBy = null },
- "https://twitter.com/Favstar_LM/status/249493863826350080",
- };
- yield return new object[] {
- new PostClass { StatusId = 216033842434289664L, ScreenName = "haru067", RetweetedId = 200245741443235840L, RetweetedBy = "re4k"},
- "https://twitter.com/haru067/status/200245741443235840",
- };
- }
- }
+ new PostClass { StatusId = 249493863826350080L, ScreenName = "Favstar_LM", RetweetedId = null, RetweetedBy = null },
+ "https://twitter.com/Favstar_LM/status/249493863826350080"
+ },
+ {
+ new PostClass { StatusId = 216033842434289664L, ScreenName = "haru067", RetweetedId = 200245741443235840L, RetweetedBy = "re4k"},
+ "https://twitter.com/haru067/status/200245741443235840"
+ },
+ };
[Theory]
- [PropertyData("GetStatusUrlTest1_TestCase")]
+ [MemberData(nameof(GetStatusUrlTest1_TestCase))]
public void GetStatusUrlTest1(PostClass post, string expected)
- {
- Assert.Equal(expected, MyCommon.GetStatusUrl(post));
- }
+ => Assert.Equal(expected, MyCommon.GetStatusUrl(post));
[Theory]
[InlineData("Favstar_LM", 249493863826350080L, "https://twitter.com/Favstar_LM/status/249493863826350080")]
[InlineData("haru067", 200245741443235840L, "https://twitter.com/haru067/status/200245741443235840")]
public void GetStatusUrlTest2(string screenName, long statusId, string expected)
- {
- Assert.Equal(expected, MyCommon.GetStatusUrl(screenName, statusId));
- }
+ => Assert.Equal(expected, MyCommon.GetStatusUrl(screenName, statusId));
[Fact]
public void GetErrorLogPathTest()
{
if (Environment.OSVersion.Platform == PlatformID.Win32NT)
{
- var mockAssembly = Substitute.For<_Assembly>();
- mockAssembly.Location.Returns(@"C:\hogehoge\OpenTween\OpenTween.exe");
- MyCommon.EntryAssembly = mockAssembly;
+ var mockAssembly = new Mock<_Assembly>();
+ mockAssembly.Setup(m => m.Location).Returns(@"C:\hogehoge\OpenTween\OpenTween.exe");
+ MyCommon.EntryAssembly = mockAssembly.Object;
Assert.Equal(@"C:\hogehoge\OpenTween\ErrorLogs", MyCommon.GetErrorLogPath());
}
else
{
- var mockAssembly = Substitute.For<_Assembly>();
- mockAssembly.Location.Returns(@"/hogehoge/OpenTween/OpenTween.exe");
- MyCommon.EntryAssembly = mockAssembly;
+ var mockAssembly = new Mock<_Assembly>();
+ mockAssembly.Setup(m => m.Location).Returns(@"/hogehoge/OpenTween/OpenTween.exe");
+ MyCommon.EntryAssembly = mockAssembly.Object;
Assert.Equal(@"/hogehoge/OpenTween/ErrorLogs", MyCommon.GetErrorLogPath());
}
}
+
+ [Fact]
+ public void CountUp_Test()
+ {
+ var actual = MyCommon.CountUp(from: 1, to: 5);
+
+ Assert.Equal(new[] { 1, 2, 3, 4, 5 }, actual);
+ }
+
+ [Fact]
+ public void CountUp_FromAndToAreEqualTest()
+ {
+ var actual = MyCommon.CountUp(from: 1, to: 1);
+
+ Assert.Equal(new[] { 1 }, actual);
+ }
+
+ [Fact]
+ public void CountUp_ToIsLessThanFromTest()
+ {
+ var actual = MyCommon.CountUp(from: 1, to: 0);
+
+ Assert.Empty(actual);
+ }
+
+ [Fact]
+ public void CountDown_Test()
+ {
+ var actual = MyCommon.CountDown(from: 5, to: 1);
+
+ Assert.Equal(new[] { 5, 4, 3, 2, 1 }, actual);
+ }
+
+ [Fact]
+ public void CountDown_FromAndToAreEqualTest()
+ {
+ var actual = MyCommon.CountDown(from: 5, to: 5);
+
+ Assert.Equal(new[] { 5 }, actual);
+ }
+
+ [Fact]
+ public void CountDown_ToIsGreaterThanFromTest()
+ {
+ var actual = MyCommon.CountDown(from: 5, to: 6);
+
+ Assert.Empty(actual);
+ }
+
+ [Fact]
+ public void CircularCountUp_Test()
+ {
+ var actual = MyCommon.CircularCountUp(length: 6, startIndex: 3);
+
+ Assert.Equal(new[] { 3, 4, 5, 0, 1, 2 }, actual);
+ }
+
+ [Fact]
+ public void CircularCountUp_StartFromZeroTest()
+ {
+ var actual = MyCommon.CircularCountUp(length: 6, startIndex: 0);
+
+ Assert.Equal(new[] { 0, 1, 2, 3, 4, 5 }, actual);
+ }
+
+ [Fact]
+ public void CircularCountDown_Test()
+ {
+ var actual = MyCommon.CircularCountDown(length: 6, startIndex: 3);
+
+ Assert.Equal(new[] { 3, 2, 1, 0, 5, 4 }, actual);
+ }
+
+ [Fact]
+ public void CircularCountDown_StartFromLastIndexTest()
+ {
+ var actual = MyCommon.CircularCountDown(length: 6, startIndex: 5);
+
+ Assert.Equal(new[] { 5, 4, 3, 2, 1, 0 }, actual);
+ }
}
}