mirror of
https://github.com/rdkit/rdkit.git
synced 2026-06-04 21:54:27 +08:00
47 lines
1.5 KiB
C#
47 lines
1.5 KiB
C#
using GraphMolWrap;
|
|
using Xunit;
|
|
|
|
|
|
namespace RdkitTests
|
|
{
|
|
public class TestMolStandardize
|
|
{
|
|
[Fact]
|
|
public void TestNormalize()
|
|
{
|
|
var smiles = "C[S+2]([O-])([O-])C([O-])C(=O)O";
|
|
var mol = RWMol.MolFromSmiles(smiles);
|
|
var normalizedMol = RDKFuncs.normalize(mol);
|
|
Assert.Equal("CS(=O)(=O)C([O-])C(=O)O", normalizedMol.MolToSmiles());
|
|
Assert.Equal(smiles, mol.MolToSmiles());
|
|
RDKFuncs.normalizeInPlace(mol);
|
|
Assert.Equal("CS(=O)(=O)C([O-])C(=O)O", mol.MolToSmiles());
|
|
}
|
|
|
|
|
|
[Fact]
|
|
public void TestCleanup()
|
|
{
|
|
var smiles = "O=C(O)[C@]([O-])(O)Cl";
|
|
var mol = RWMol.MolFromSmiles(smiles);
|
|
var cleanedMol = RDKFuncs.cleanup(mol);
|
|
Assert.Equal("O=C([O-])C(O)(O)Cl", cleanedMol.MolToSmiles());
|
|
Assert.Equal(smiles, mol.MolToSmiles());
|
|
RDKFuncs.cleanupInPlace(mol);
|
|
Assert.Equal("O=C([O-])C(O)(O)Cl", mol.MolToSmiles());
|
|
}
|
|
|
|
|
|
[Fact]
|
|
public void TestCanonicalTautomer()
|
|
{
|
|
var smiles = "CP(C)O";
|
|
var mol = RWMol.MolFromSmiles(smiles);
|
|
var tautomer = RDKFuncs.canonicalTautomer(mol);
|
|
Assert.Equal("C[PH](C)=O", tautomer.MolToSmiles());
|
|
Assert.Equal(smiles, mol.MolToSmiles());
|
|
RDKFuncs.canonicalTautomerInPlace(mol);
|
|
Assert.Equal("C[PH](C)=O", mol.MolToSmiles());
|
|
}
|
|
}
|
|
} |